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. Error/Bug
  4. Error im admin.0 [Alias subscription error]

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    15
    1
    551

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    1.9k

Error im admin.0 [Alias subscription error]

Geplant Angeheftet Gesperrt Verschoben Error/Bug
17 Beiträge 3 Kommentatoren 1.4k Aufrufe 1 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • F Flopsi
    Systemdata
    Hardwaresystem: PI4
    Arbeitsspeicher: 8GB
    Festplattenart: SSD
    Betriebssystem: Linux
    Node-Version: 18.18.2
    Nodejs-Version: 18.18.2
    NPM-Version: 9.8.1
    Installationsart: -
    Image genutzt: -
    Ort/Name der Imagedatei: -

    Ich habe hin und wieder folgenden ERROR :

    admin.0
    	2023-11-01 09:44:26.972	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_065.Binary_Sensor.motion, sourceObj={"type":"state","common":{"role":"indicator","read":true,"write":false,"name":"Sensor state (Motion)","type":"boolean"},"native":{"nodeId":65,"valueId":{"commandClass":48,"endpoint":0,"property":"Motion"}},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1698334268930,"_id":"zwave2.0.Node_065.Binary_Sensor.motion","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
    admin.0
    	2023-11-01 09:44:26.973	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_065.Multilevel_Sensor.humidity, sourceObj={"type":"state","common":{"role":"value","read":true,"write":false,"name":"Humidity","type":"number","unit":"%"},"native":{"nodeId":65,"valueId":{"commandClass":49,"endpoint":0,"property":"Humidity"}},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1698334270043,"_id":"zwave2.0.Node_065.Multilevel_Sensor.humidity","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
    admin.0
    	2023-11-01 09:44:26.974	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_065.Multilevel_Sensor.illuminance, sourceObj={"type":"state","common":{"role":"value","read":true,"write":false,"name":"Illuminance","type":"number","unit":"Lux"},"native":{"nodeId":65,"valueId":{"commandClass":49,"endpoint":0,"property":"Illuminance"}},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1698334269984,"_id":"zwave2.0.Node_065.Multilevel_Sensor.illuminance","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
    admin.0
    	2023-11-01 09:44:26.975	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_065.Multilevel_Sensor.airTemperature, sourceObj={"type":"state","common":{"role":"value","read":true,"write":false,"name":"Air temperature","type":"number","unit":"°C"},"native":{"nodeId":65,"valueId":{"commandClass":49,"endpoint":0,"property":"Air temperature"}},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1698334269209,"_id":"zwave2.0.Node_065.Multilevel_Sensor.airTemperature","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
    admin.0
    	2023-11-01 09:44:26.975	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_064.Binary_Sensor.motion, sourceObj={"type":"state","common":{"role":"indicator","read":true,"write":false,"name":"Sensor state (Motion)","type":"boolean"},"native":{"nodeId":64,"valueId":{"commandClass":48,"endpoint":0,"property":"Motion"}},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1697812897069,"_id":"zwave2.0.Node_064.Binary_Sensor.motion","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
    admin.0
    	2023-11-01 09:44:26.976	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_064.Multilevel_Sensor.humidity, sourceObj={"type":"state","common":{"role":"value","read":true,"write":false,"name":"Humidity","type":"number","unit":"%","custom":{"history.0":{"enabled":true,"aliasId":"","debounceTime":0,"blockTime":0,"changesOnly":true,"changesRelogInterval":0,"changesMinDelta":0,"ignoreBelowNumber":"","disableSkippedValueLogging":false,"retention":31536000,"customRetentionDuration":365,"maxLength":960,"enableDebugLogs":false,"debounce":1000}}},"native":{"nodeId":64,"valueId":{"commandClass":49,"endpoint":0,"property":"Humidity"}},"_id":"zwave2.0.Node_064.Multilevel_Sensor.humidity","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1698827722577}
    admin.0
    	2023-11-01 09:44:26.977	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_064.Multilevel_Sensor.illuminance, sourceObj={"type":"state","common":{"role":"value","read":true,"write":false,"name":"Illuminance","type":"number","unit":"Lux","custom":{"history.0":{"enabled":true,"aliasId":"","debounceTime":0,"blockTime":0,"changesOnly":true,"changesRelogInterval":0,"changesMinDelta":0,"ignoreBelowNumber":"","disableSkippedValueLogging":false,"retention":31536000,"customRetentionDuration":365,"maxLength":960,"enableDebugLogs":false,"debounce":1000}}},"native":{"nodeId":64,"valueId":{"commandClass":49,"endpoint":0,"property":"Illuminance"}},"_id":"zwave2.0.Node_064.Multilevel_Sensor.illuminance","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1698827724985}
    admin.0
    	2023-11-01 09:44:26.977	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_064.Multilevel_Sensor.airTemperature, sourceObj={"type":"state","common":{"role":"value","read":true,"write":false,"name":"Air temperature","type":"number","unit":"°C"},"native":{"nodeId":64,"valueId":{"commandClass":49,"endpoint":0,"property":"Air temperature"}},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1697812898332,"_id":"zwave2.0.Node_064.Multilevel_Sensor.airTemperature","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
    

    Die Fehlermeldungen sind erst seitdem ich meine beiden Multi 7 Sensoren von Aeotec über Zwave 2 eingebunden habe.
    Die Sensoren funktionieren eigentlich so wie sie sollen.

    Weis wer was hier den Fehler verursacht ?

    @AlCalzone evtl. ?

    Thomas BraunT Online
    Thomas BraunT Online
    Thomas Braun
    Most Active
    schrieb am zuletzt editiert von
    #2

    @flopsi

    Nodejs-Version: 18.17.1

    Du stehst offenbar auf dem Abstellgleis, was nodejs angeht

    iob nodejs-update
    

    ausführen, ggfs. zuvor iob fix

    Linux-Werkzeugkasten:
    https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
    NodeJS Fixer Skript:
    https://forum.iobroker.net/topic/68035/iob-node-fix-skript
    iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

    F 1 Antwort Letzte Antwort
    0
    • Thomas BraunT Thomas Braun

      @flopsi

      Nodejs-Version: 18.17.1

      Du stehst offenbar auf dem Abstellgleis, was nodejs angeht

      iob nodejs-update
      

      ausführen, ggfs. zuvor iob fix

      F Offline
      F Offline
      Flopsi
      schrieb am zuletzt editiert von
      #3

      @thomas-braun

      ioBroker nodejs fixer 2023-10-13
      
      Recommended nodejs-version is: 18.18.2
      Checking your installation now. Please be patient!
      
      Your current setup is:
      /usr/bin/nodejs         v18.17.1
      /usr/bin/node           v18.17.1
      /usr/bin/npm            9.6.7
      /usr/bin/npx            9.6.7
      /usr/bin/corepack       0.18.0
      
      We found these nodejs versions available for installation:
      
      nodejs:
        Installed: 18.17.1-deb-1nodesource1
        Candidate: 18.17.1-deb-1nodesource1
        Version table:
       *** 18.17.1-deb-1nodesource1 500
              500 https://deb.nodesource.com/node_18.x bullseye/main arm64 Packages
              100 /var/lib/dpkg/status
           12.22.12~dfsg-1~deb11u4 500
              500 http://deb.debian.org/debian bullseye/main arm64 Packages
              500 http://security.debian.org/debian-security bullseye-security/main ar                                          m64 Packages
      
      
      
      Nothing to do - Your installation is using the correct paths.
      
      You are running nodejs v18.17.1. Do you want to install recommended version 18.1                                          8.2?
      
      Press <y> to continue or any other key to quit
      
      
      Thomas BraunT 1 Antwort Letzte Antwort
      0
      • F Flopsi

        @thomas-braun

        ioBroker nodejs fixer 2023-10-13
        
        Recommended nodejs-version is: 18.18.2
        Checking your installation now. Please be patient!
        
        Your current setup is:
        /usr/bin/nodejs         v18.17.1
        /usr/bin/node           v18.17.1
        /usr/bin/npm            9.6.7
        /usr/bin/npx            9.6.7
        /usr/bin/corepack       0.18.0
        
        We found these nodejs versions available for installation:
        
        nodejs:
          Installed: 18.17.1-deb-1nodesource1
          Candidate: 18.17.1-deb-1nodesource1
          Version table:
         *** 18.17.1-deb-1nodesource1 500
                500 https://deb.nodesource.com/node_18.x bullseye/main arm64 Packages
                100 /var/lib/dpkg/status
             12.22.12~dfsg-1~deb11u4 500
                500 http://deb.debian.org/debian bullseye/main arm64 Packages
                500 http://security.debian.org/debian-security bullseye-security/main ar                                          m64 Packages
        
        
        
        Nothing to do - Your installation is using the correct paths.
        
        You are running nodejs v18.17.1. Do you want to install recommended version 18.1                                          8.2?
        
        Press <y> to continue or any other key to quit
        
        
        Thomas BraunT Online
        Thomas BraunT Online
        Thomas Braun
        Most Active
        schrieb am zuletzt editiert von
        #4

        @flopsi

        Siehste. 18.18.2 ist aktuell angesagt...

        Linux-Werkzeugkasten:
        https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
        NodeJS Fixer Skript:
        https://forum.iobroker.net/topic/68035/iob-node-fix-skript
        iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

        F 1 Antwort Letzte Antwort
        0
        • Thomas BraunT Thomas Braun

          @flopsi

          Siehste. 18.18.2 ist aktuell angesagt...

          F Offline
          F Offline
          Flopsi
          schrieb am zuletzt editiert von
          #5

          @thomas-braun

          OK bin auf der neusten Version dann schaue ich erstmal ob der Error wieder auftritt ...

          Thomas BraunT 1 Antwort Letzte Antwort
          0
          • F Flopsi

            @thomas-braun

            OK bin auf der neusten Version dann schaue ich erstmal ob der Error wieder auftritt ...

            Thomas BraunT Online
            Thomas BraunT Online
            Thomas Braun
            Most Active
            schrieb am zuletzt editiert von
            #6

            @flopsi
            Nein, der hat damit nix zu tun. War aber dennoch falsch.

            Linux-Werkzeugkasten:
            https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
            NodeJS Fixer Skript:
            https://forum.iobroker.net/topic/68035/iob-node-fix-skript
            iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

            F 1 Antwort Letzte Antwort
            0
            • Thomas BraunT Thomas Braun

              @flopsi
              Nein, der hat damit nix zu tun. War aber dennoch falsch.

              F Offline
              F Offline
              Flopsi
              schrieb am zuletzt editiert von
              #7

              @thomas-braun

              Zu meinem eigentlichen Problem hast du keine Idee ?

              Thomas BraunT 1 Antwort Letzte Antwort
              0
              • F Flopsi

                @thomas-braun

                Zu meinem eigentlichen Problem hast du keine Idee ?

                Thomas BraunT Online
                Thomas BraunT Online
                Thomas Braun
                Most Active
                schrieb am zuletzt editiert von
                #8

                @flopsi

                Dann hätte ich dazu was geschrieben.

                Linux-Werkzeugkasten:
                https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                NodeJS Fixer Skript:
                https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                1 Antwort Letzte Antwort
                0
                • F Flopsi
                  Systemdata
                  Hardwaresystem: PI4
                  Arbeitsspeicher: 8GB
                  Festplattenart: SSD
                  Betriebssystem: Linux
                  Node-Version: 18.18.2
                  Nodejs-Version: 18.18.2
                  NPM-Version: 9.8.1
                  Installationsart: -
                  Image genutzt: -
                  Ort/Name der Imagedatei: -

                  Ich habe hin und wieder folgenden ERROR :

                  admin.0
                  	2023-11-01 09:44:26.972	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_065.Binary_Sensor.motion, sourceObj={"type":"state","common":{"role":"indicator","read":true,"write":false,"name":"Sensor state (Motion)","type":"boolean"},"native":{"nodeId":65,"valueId":{"commandClass":48,"endpoint":0,"property":"Motion"}},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1698334268930,"_id":"zwave2.0.Node_065.Binary_Sensor.motion","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
                  admin.0
                  	2023-11-01 09:44:26.973	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_065.Multilevel_Sensor.humidity, sourceObj={"type":"state","common":{"role":"value","read":true,"write":false,"name":"Humidity","type":"number","unit":"%"},"native":{"nodeId":65,"valueId":{"commandClass":49,"endpoint":0,"property":"Humidity"}},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1698334270043,"_id":"zwave2.0.Node_065.Multilevel_Sensor.humidity","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
                  admin.0
                  	2023-11-01 09:44:26.974	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_065.Multilevel_Sensor.illuminance, sourceObj={"type":"state","common":{"role":"value","read":true,"write":false,"name":"Illuminance","type":"number","unit":"Lux"},"native":{"nodeId":65,"valueId":{"commandClass":49,"endpoint":0,"property":"Illuminance"}},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1698334269984,"_id":"zwave2.0.Node_065.Multilevel_Sensor.illuminance","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
                  admin.0
                  	2023-11-01 09:44:26.975	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_065.Multilevel_Sensor.airTemperature, sourceObj={"type":"state","common":{"role":"value","read":true,"write":false,"name":"Air temperature","type":"number","unit":"°C"},"native":{"nodeId":65,"valueId":{"commandClass":49,"endpoint":0,"property":"Air temperature"}},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1698334269209,"_id":"zwave2.0.Node_065.Multilevel_Sensor.airTemperature","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
                  admin.0
                  	2023-11-01 09:44:26.975	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_064.Binary_Sensor.motion, sourceObj={"type":"state","common":{"role":"indicator","read":true,"write":false,"name":"Sensor state (Motion)","type":"boolean"},"native":{"nodeId":64,"valueId":{"commandClass":48,"endpoint":0,"property":"Motion"}},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1697812897069,"_id":"zwave2.0.Node_064.Binary_Sensor.motion","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
                  admin.0
                  	2023-11-01 09:44:26.976	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_064.Multilevel_Sensor.humidity, sourceObj={"type":"state","common":{"role":"value","read":true,"write":false,"name":"Humidity","type":"number","unit":"%","custom":{"history.0":{"enabled":true,"aliasId":"","debounceTime":0,"blockTime":0,"changesOnly":true,"changesRelogInterval":0,"changesMinDelta":0,"ignoreBelowNumber":"","disableSkippedValueLogging":false,"retention":31536000,"customRetentionDuration":365,"maxLength":960,"enableDebugLogs":false,"debounce":1000}}},"native":{"nodeId":64,"valueId":{"commandClass":49,"endpoint":0,"property":"Humidity"}},"_id":"zwave2.0.Node_064.Multilevel_Sensor.humidity","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1698827722577}
                  admin.0
                  	2023-11-01 09:44:26.977	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_064.Multilevel_Sensor.illuminance, sourceObj={"type":"state","common":{"role":"value","read":true,"write":false,"name":"Illuminance","type":"number","unit":"Lux","custom":{"history.0":{"enabled":true,"aliasId":"","debounceTime":0,"blockTime":0,"changesOnly":true,"changesRelogInterval":0,"changesMinDelta":0,"ignoreBelowNumber":"","disableSkippedValueLogging":false,"retention":31536000,"customRetentionDuration":365,"maxLength":960,"enableDebugLogs":false,"debounce":1000}}},"native":{"nodeId":64,"valueId":{"commandClass":49,"endpoint":0,"property":"Illuminance"}},"_id":"zwave2.0.Node_064.Multilevel_Sensor.illuminance","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1698827724985}
                  admin.0
                  	2023-11-01 09:44:26.977	error	Alias subscription error. Please check your alias definitions: sourceId=zwave2.0.Node_064.Multilevel_Sensor.airTemperature, sourceObj={"type":"state","common":{"role":"value","read":true,"write":false,"name":"Air temperature","type":"number","unit":"°C"},"native":{"nodeId":64,"valueId":{"commandClass":49,"endpoint":0,"property":"Air temperature"}},"from":"system.adapter.zwave2.0","user":"system.user.admin","ts":1697812898332,"_id":"zwave2.0.Node_064.Multilevel_Sensor.airTemperature","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
                  

                  Die Fehlermeldungen sind erst seitdem ich meine beiden Multi 7 Sensoren von Aeotec über Zwave 2 eingebunden habe.
                  Die Sensoren funktionieren eigentlich so wie sie sollen.

                  Weis wer was hier den Fehler verursacht ?

                  @AlCalzone evtl. ?

                  haus-automatisierungH Offline
                  haus-automatisierungH Offline
                  haus-automatisierung
                  Developer Most Active
                  schrieb am zuletzt editiert von
                  #9

                  @flopsi Dann zeig doch mal, wie der Alias definiert ist

                  🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                  🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                  📚 Meine inoffizielle ioBroker Dokumentation

                  F 1 Antwort Letzte Antwort
                  0
                  • haus-automatisierungH haus-automatisierung

                    @flopsi Dann zeig doch mal, wie der Alias definiert ist

                    F Offline
                    F Offline
                    Flopsi
                    schrieb am zuletzt editiert von
                    #10

                    @haus-automatisierung

                    createAlias('zwave2.0.Node_065.Multilevel_Sensor.illuminance','Flur.Multisensor.Aeotec_7.Lux');
                    createAlias('zwave2.0.Node_065.Multilevel_Sensor.airTemperature','Flur.Multisensor.Aeotec_7.Temp');
                    createAlias('zwave2.0.Node_065.Binary_Sensor.motion','Flur.Multisensor.Aeotec_7.Bewegung');
                    createAlias('zwave2.0.Node_065.Multilevel_Sensor.humidity','Flur.Multisensor.Aeotec_7.Luftfeuchtigkeit');
                    
                    createAlias('zwave2.0.Node_064.Multilevel_Sensor.illuminance','Kueche.Multisensor.Aeotec_7.Lux');
                    createAlias('zwave2.0.Node_064.Multilevel_Sensor.airTemperature','Kueche.Multisensor.Aeotec_7.Temp');
                    createAlias('zwave2.0.Node_064.Binary_Sensor.motion','Kueche.Multisensor.Aeotec_7.Bewegung');
                    createAlias('zwave2.0.Node_064.Multilevel_Sensor.humidity','Kueche.Multisensor.Aeotec_7.Luftfeuchtigkeit');
                    
                    haus-automatisierungH 1 Antwort Letzte Antwort
                    0
                    • F Flopsi

                      @haus-automatisierung

                      createAlias('zwave2.0.Node_065.Multilevel_Sensor.illuminance','Flur.Multisensor.Aeotec_7.Lux');
                      createAlias('zwave2.0.Node_065.Multilevel_Sensor.airTemperature','Flur.Multisensor.Aeotec_7.Temp');
                      createAlias('zwave2.0.Node_065.Binary_Sensor.motion','Flur.Multisensor.Aeotec_7.Bewegung');
                      createAlias('zwave2.0.Node_065.Multilevel_Sensor.humidity','Flur.Multisensor.Aeotec_7.Luftfeuchtigkeit');
                      
                      createAlias('zwave2.0.Node_064.Multilevel_Sensor.illuminance','Kueche.Multisensor.Aeotec_7.Lux');
                      createAlias('zwave2.0.Node_064.Multilevel_Sensor.airTemperature','Kueche.Multisensor.Aeotec_7.Temp');
                      createAlias('zwave2.0.Node_064.Binary_Sensor.motion','Kueche.Multisensor.Aeotec_7.Bewegung');
                      createAlias('zwave2.0.Node_064.Multilevel_Sensor.humidity','Kueche.Multisensor.Aeotec_7.Luftfeuchtigkeit');
                      
                      haus-automatisierungH Offline
                      haus-automatisierungH Offline
                      haus-automatisierung
                      Developer Most Active
                      schrieb am zuletzt editiert von haus-automatisierung
                      #11

                      @flopsi Ich meine die Objekt-Definition vom erstellten Alias

                      EDIT: Du benutzt createAlias falsch. Gerade mal in die Doku geschaut.

                      • name ist die ID des Alias und
                      • alias ist die ID, auf welcher sich dieser bezieht.

                      Also die Parameter einmal umdrehen jeweils.

                      🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                      🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                      📚 Meine inoffizielle ioBroker Dokumentation

                      F 1 Antwort Letzte Antwort
                      0
                      • haus-automatisierungH haus-automatisierung

                        @flopsi Ich meine die Objekt-Definition vom erstellten Alias

                        EDIT: Du benutzt createAlias falsch. Gerade mal in die Doku geschaut.

                        • name ist die ID des Alias und
                        • alias ist die ID, auf welcher sich dieser bezieht.

                        Also die Parameter einmal umdrehen jeweils.

                        F Offline
                        F Offline
                        Flopsi
                        schrieb am zuletzt editiert von
                        #12

                        @haus-automatisierung sagte in Error im admin.0 [Alias subscription error]:

                        createAlias

                        Versteh nicht was ich umdrehen soll ? Kannst du mir ein Beispiel zeigen ?

                        Ich erstelle all meine Alias nach dem Schema nie probleme gehabt erst seit den neuen Sensoren...

                        Ich nutze das folgendes Skript für:

                        /**************************************************************
                        Github - https://github.com/xCruziX/ioBroker-Creating-Alias/blob/master/CreateAlias.js
                        				Changelog
                        Version 1.1.3
                          - use callbacks in alias-path
                        Version 1.1.2
                          - fix log message 'Created Alias-Path '
                        Version 1.1.1
                          - Bugfixing, clean functions
                        Version 1.1.0
                          - added function for cleaning enums
                        Version 1.0.6
                          - use callback functions for safety call
                        Version 1.0.5
                          - decrease timeout assing enum 
                        Version 1.0.4
                          - Bugfixing array id lenght
                        Version 1.0.3
                          - Githublink 
                        Version 1.0.2
                          - existsObject for Alias in the timeout
                          - remove lowerCase enum
                          - improved logs
                        Version 1.0.1
                          - Rooms and functions casesensitive
                        Version 1.0
                        **************************************************************/
                        
                        /**************************************
                        		Flags /
                        		Variablen
                        ***************************************/
                        
                        // typeAlias = 'boolean'; // oder 'number'
                        // read = "val == 'Ein' ? true : false"; // Erkennung "Aus" --> false erfolgt automatisch  
                        // write = "val ? 'Ein' : 'Aus'";
                        // nameAlias = 'Licht Haustür';
                        // role = 'switch';
                        // desc = 'per Script erstellt';
                        // min = 0; // nur Zahlen
                        // max = 100; // nur Zahlen
                        // unit = '%'; // nur für Zahlen
                        // states = {0: 'Aus', 1: 'Auto', 2: 'Ein'}; // Zahlen (Multistate) oder Logikwert (z.B. Aus/Ein)
                         
                        let bCreateAliasPath = false;  // If this flag is true, each folder is created seperately so rooms and functions can be assigned.
                        
                        /*
                        Requirements: bCreateAliasPath == true
                        If this flag is true, existing folders in the path will be converted so rooms and functions can be assigned.
                        */
                        let bConvertExistingPath = false;
                        
                        /**********************************************************
                        	Don't change anything from here /
                        	Ab hier nichts verändern
                        **********************************************************/
                        
                        let arEnum = [];
                        let arId = [];
                        let timeoutAssignEnum;
                        function createAlias(idSrc, idDst,raum, gewerk,typeAlias, read, write, nameAlias, role, desc, min, max, unit, states) {
                          if(!idDst.includes('alias.0.'))
                              idDst = 'alias.0.' + idDst;
                          if(!existsObject(idSrc))
                          {
                              log('Source-Id ' + idSrc +' does not exists.','warn');
                              return;
                          }
                          
                          // Create the object Path for alias id, 
                          // so you can assign rooms and function to the parents
                          var createAliasPath = (id) => {
                               if(bCreateAliasPath){
                                    let lisMergedIds = [];
                                    let mergedId = 'alias.0';
                                    id = id.replace(mergedId + '.', ''); // Remove prefix alias so it will not be changed
                                    let split = id.split('.'); 
                                    for(let i=0;i<split.length-1;i++){
                                        mergedId += '.' + split[i];
                                        lisMergedIds.push(mergedId);
                                    }
                                    
                                    function path(){
                                        if(lisMergedIds.length == 0) {// Zu Ende erstellt
                                            alias();
                                            return;
                                        }
                                        let tmpId = lisMergedIds[0];
                                        lisMergedIds.splice(0,1); // entferne element
                                        if(!existsObject(tmpId) || bConvertExistingPath){ // not exists
                                            let obj;
                                            if(existsObject(tmpId))
                                                obj = getObject(tmpId);
                                            else
                                                obj = {};
                        
                                            if(obj.type == undefined || obj.type != 'meta')
                                                obj.type = 'meta';
                                            if(obj.common == undefined || obj.common != {})
                                                obj.common = {};
                                            if(obj.common.type == undefined || obj.common.type != 'meta.folder')
                                                obj.common.type = 'meta.folder';
                                            if(obj.common.desc == undefined || obj.common.desc != 'createAliasPath')
                                                obj.common.desc = 'createAliasPath';
                                            if(obj.common.def == undefined || obj.common.def != false)
                                                obj.common.def = false;
                                            if(obj.native == undefined || obj.native != {})
                                                obj.native = {};
                        
                                            
                                            setObject(tmpId, obj, (err) =>{
                                                if(!err){
                                                    log('Created Alias-Path ' + tmpId);
                                                    path();
                                                }
                                                else
                                                    log('Error creating alias-path','error');
                                            });
                                        }
                                    }
                                    path();
                               }
                               else
                                 alias();
                          }
                          
                         
                            //   createAliasPath(idDst);
                          
                          function alias(){
                              // Create alias object
                              
                                if(!existsObject(idDst)){
                                    let obj = {};
                                    obj.type = 'state';
                                    obj.common = getObject(idSrc).common;
                                    obj.common.alias = {};
                                    obj.common.alias.id = idSrc;
                                    if(typeAlias !== undefined) 
                                        obj.common.type = typeAlias;
                                    if(obj.common.read !== undefined) 
                                        obj.common.alias.read = read;
                                    if(obj.common.write !== undefined) 
                                        obj.common.alias.write = write;
                                    if(nameAlias !== undefined) 
                                        obj.common.name = nameAlias;
                                    if(role !== undefined) 
                                        obj.common.role = role;
                                    if(desc !== undefined) 
                                        obj.common.desc = desc;
                                    if(min !== undefined) 
                                        obj.common.min = min;
                                    if(max !== undefined) 
                                        obj.common.max = max;
                                    if(unit !== undefined) 
                                        obj.common.unit = unit;
                                    if(states !== undefined) 
                                        obj.common.states = states;
                        
                                    obj.native = {};
                                    obj.common.custom = []; // Damit die Zuordnung zu iQontrol, Sql etc. nicht übernommen wird
                                    log('Created Alias-State ' + idDst);
                                    setObject(idDst, obj,(err) =>{ 
                                        if(!err)
                                            startAttach(); 
                                        else
                                            log('Error creating-alias','error');
                                    });
                                }
                                else
                                    startAttach();
                          }
                          
                          
                          // Save ID and Enum (room or function)
                          var attach = (id, enu,value) => {
                              if(id.length == 0){
                                  log('ID has lenght 0, can not attach to enum','warn');
                                  return;
                              }
                              if(value.length == 0){
                                  log('Value has lenght 0','warn');
                                  return;
                              }
                            
                              let sEnuId = 'enum.' + enu + '.' + value;
                              if(enu.length > 0 && existsObject(sEnuId)) 
                              {
                                  let obj = getObject(sEnuId)
                                  let members = obj.common.members;
                                  if(!members.includes(id)){
                                      arEnum.push(sEnuId);
                                      arId.push(id);
                                  }
                              }
                              else
                           	      log('Can not find enum ' + sEnuId,'warn');
                          }
                         
                         function startAttach(){
                            let bRoom = raum !== undefined && raum.length > 0;
                            let bGewerk = gewerk !== undefined && gewerk.length > 0;
                            
                            if(bRoom)
                                attach(idDst,'rooms',raum);
                            if(bGewerk)
                                attach(idDst,'functions',gewerk);
                            if(bRoom || bGewerk){
                                    if(timeoutAssignEnum){
                                        clearTimeout(timeoutAssignEnum);
                                        timeoutAssignEnum = null;
                                    }
                                    timeoutAssignEnum = setTimeout(finishScript,100);
                            }
                         }
                         
                          createAliasPath(idDst);
                        }
                        
                        function finishScript(){
                        	assignEnums();
                        }
                        
                        // Add the saved IDs to the rooms/functions
                        function assignEnums(){
                         if(arEnum.length == 0 || arId.length == 0){
                              return;
                         }
                        
                         if(arEnum.length != arId.length){
                              log('Arrays have different size','error');
                              return;
                         }
                         let mapEnumId = new Map();
                         
                         for(let i=0;i < arEnum.length; i++){
                             let enu = arEnum[i];
                             let id = arId[i];
                             if(existsObject(id)){
                            	 let obj = getObject(enu)
                            	 let members;
                            	 if(!mapEnumId.has(enu)){
                            		 members = obj.common.members;
                            		 mapEnumId.set(enu,members);
                            	 }
                            	 else
                            		 members = mapEnumId.get(enu);    
                            	 if(!members.includes(id)){
                            		  log("Adding " + id + " to " + enu);
                            		  members.push(id);
                            	 }	      
                             }
                             else
                                 log('Can not find Alias ' + id,'error');
                         }
                          
                          function setMembers(members,enu,map){
                              let obj = getObject(enu);
                              obj.common.members = members;
                              setObject(enu,obj);
                          }
                          mapEnumId.forEach(setMembers);
                        }
                        

                        Hier noch die Objekt-Definition: ( Ich hoffe es ist die richtige das gibt es ja zu jedem Datenpunkt eine ....

                        {
                          "type": "channel",
                          "common": {
                            "name": "alias.0.Flur.Multisensor.Aeotec_7"
                          },
                          "_id": "alias.0.Flur.Multisensor.Aeotec_7",
                          "native": {},
                          "from": "system.adapter.admin.0",
                          "user": "system.user.admin",
                          "ts": 1698686702683,
                          "acl": {
                            "object": 1636,
                            "owner": "system.user.admin",
                            "ownerGroup": "system.group.administrator"
                          }
                        }
                        
                        haus-automatisierungH 2 Antworten Letzte Antwort
                        0
                        • F Flopsi

                          @haus-automatisierung sagte in Error im admin.0 [Alias subscription error]:

                          createAlias

                          Versteh nicht was ich umdrehen soll ? Kannst du mir ein Beispiel zeigen ?

                          Ich erstelle all meine Alias nach dem Schema nie probleme gehabt erst seit den neuen Sensoren...

                          Ich nutze das folgendes Skript für:

                          /**************************************************************
                          Github - https://github.com/xCruziX/ioBroker-Creating-Alias/blob/master/CreateAlias.js
                          				Changelog
                          Version 1.1.3
                            - use callbacks in alias-path
                          Version 1.1.2
                            - fix log message 'Created Alias-Path '
                          Version 1.1.1
                            - Bugfixing, clean functions
                          Version 1.1.0
                            - added function for cleaning enums
                          Version 1.0.6
                            - use callback functions for safety call
                          Version 1.0.5
                            - decrease timeout assing enum 
                          Version 1.0.4
                            - Bugfixing array id lenght
                          Version 1.0.3
                            - Githublink 
                          Version 1.0.2
                            - existsObject for Alias in the timeout
                            - remove lowerCase enum
                            - improved logs
                          Version 1.0.1
                            - Rooms and functions casesensitive
                          Version 1.0
                          **************************************************************/
                          
                          /**************************************
                          		Flags /
                          		Variablen
                          ***************************************/
                          
                          // typeAlias = 'boolean'; // oder 'number'
                          // read = "val == 'Ein' ? true : false"; // Erkennung "Aus" --> false erfolgt automatisch  
                          // write = "val ? 'Ein' : 'Aus'";
                          // nameAlias = 'Licht Haustür';
                          // role = 'switch';
                          // desc = 'per Script erstellt';
                          // min = 0; // nur Zahlen
                          // max = 100; // nur Zahlen
                          // unit = '%'; // nur für Zahlen
                          // states = {0: 'Aus', 1: 'Auto', 2: 'Ein'}; // Zahlen (Multistate) oder Logikwert (z.B. Aus/Ein)
                           
                          let bCreateAliasPath = false;  // If this flag is true, each folder is created seperately so rooms and functions can be assigned.
                          
                          /*
                          Requirements: bCreateAliasPath == true
                          If this flag is true, existing folders in the path will be converted so rooms and functions can be assigned.
                          */
                          let bConvertExistingPath = false;
                          
                          /**********************************************************
                          	Don't change anything from here /
                          	Ab hier nichts verändern
                          **********************************************************/
                          
                          let arEnum = [];
                          let arId = [];
                          let timeoutAssignEnum;
                          function createAlias(idSrc, idDst,raum, gewerk,typeAlias, read, write, nameAlias, role, desc, min, max, unit, states) {
                            if(!idDst.includes('alias.0.'))
                                idDst = 'alias.0.' + idDst;
                            if(!existsObject(idSrc))
                            {
                                log('Source-Id ' + idSrc +' does not exists.','warn');
                                return;
                            }
                            
                            // Create the object Path for alias id, 
                            // so you can assign rooms and function to the parents
                            var createAliasPath = (id) => {
                                 if(bCreateAliasPath){
                                      let lisMergedIds = [];
                                      let mergedId = 'alias.0';
                                      id = id.replace(mergedId + '.', ''); // Remove prefix alias so it will not be changed
                                      let split = id.split('.'); 
                                      for(let i=0;i<split.length-1;i++){
                                          mergedId += '.' + split[i];
                                          lisMergedIds.push(mergedId);
                                      }
                                      
                                      function path(){
                                          if(lisMergedIds.length == 0) {// Zu Ende erstellt
                                              alias();
                                              return;
                                          }
                                          let tmpId = lisMergedIds[0];
                                          lisMergedIds.splice(0,1); // entferne element
                                          if(!existsObject(tmpId) || bConvertExistingPath){ // not exists
                                              let obj;
                                              if(existsObject(tmpId))
                                                  obj = getObject(tmpId);
                                              else
                                                  obj = {};
                          
                                              if(obj.type == undefined || obj.type != 'meta')
                                                  obj.type = 'meta';
                                              if(obj.common == undefined || obj.common != {})
                                                  obj.common = {};
                                              if(obj.common.type == undefined || obj.common.type != 'meta.folder')
                                                  obj.common.type = 'meta.folder';
                                              if(obj.common.desc == undefined || obj.common.desc != 'createAliasPath')
                                                  obj.common.desc = 'createAliasPath';
                                              if(obj.common.def == undefined || obj.common.def != false)
                                                  obj.common.def = false;
                                              if(obj.native == undefined || obj.native != {})
                                                  obj.native = {};
                          
                                              
                                              setObject(tmpId, obj, (err) =>{
                                                  if(!err){
                                                      log('Created Alias-Path ' + tmpId);
                                                      path();
                                                  }
                                                  else
                                                      log('Error creating alias-path','error');
                                              });
                                          }
                                      }
                                      path();
                                 }
                                 else
                                   alias();
                            }
                            
                           
                              //   createAliasPath(idDst);
                            
                            function alias(){
                                // Create alias object
                                
                                  if(!existsObject(idDst)){
                                      let obj = {};
                                      obj.type = 'state';
                                      obj.common = getObject(idSrc).common;
                                      obj.common.alias = {};
                                      obj.common.alias.id = idSrc;
                                      if(typeAlias !== undefined) 
                                          obj.common.type = typeAlias;
                                      if(obj.common.read !== undefined) 
                                          obj.common.alias.read = read;
                                      if(obj.common.write !== undefined) 
                                          obj.common.alias.write = write;
                                      if(nameAlias !== undefined) 
                                          obj.common.name = nameAlias;
                                      if(role !== undefined) 
                                          obj.common.role = role;
                                      if(desc !== undefined) 
                                          obj.common.desc = desc;
                                      if(min !== undefined) 
                                          obj.common.min = min;
                                      if(max !== undefined) 
                                          obj.common.max = max;
                                      if(unit !== undefined) 
                                          obj.common.unit = unit;
                                      if(states !== undefined) 
                                          obj.common.states = states;
                          
                                      obj.native = {};
                                      obj.common.custom = []; // Damit die Zuordnung zu iQontrol, Sql etc. nicht übernommen wird
                                      log('Created Alias-State ' + idDst);
                                      setObject(idDst, obj,(err) =>{ 
                                          if(!err)
                                              startAttach(); 
                                          else
                                              log('Error creating-alias','error');
                                      });
                                  }
                                  else
                                      startAttach();
                            }
                            
                            
                            // Save ID and Enum (room or function)
                            var attach = (id, enu,value) => {
                                if(id.length == 0){
                                    log('ID has lenght 0, can not attach to enum','warn');
                                    return;
                                }
                                if(value.length == 0){
                                    log('Value has lenght 0','warn');
                                    return;
                                }
                              
                                let sEnuId = 'enum.' + enu + '.' + value;
                                if(enu.length > 0 && existsObject(sEnuId)) 
                                {
                                    let obj = getObject(sEnuId)
                                    let members = obj.common.members;
                                    if(!members.includes(id)){
                                        arEnum.push(sEnuId);
                                        arId.push(id);
                                    }
                                }
                                else
                             	      log('Can not find enum ' + sEnuId,'warn');
                            }
                           
                           function startAttach(){
                              let bRoom = raum !== undefined && raum.length > 0;
                              let bGewerk = gewerk !== undefined && gewerk.length > 0;
                              
                              if(bRoom)
                                  attach(idDst,'rooms',raum);
                              if(bGewerk)
                                  attach(idDst,'functions',gewerk);
                              if(bRoom || bGewerk){
                                      if(timeoutAssignEnum){
                                          clearTimeout(timeoutAssignEnum);
                                          timeoutAssignEnum = null;
                                      }
                                      timeoutAssignEnum = setTimeout(finishScript,100);
                              }
                           }
                           
                            createAliasPath(idDst);
                          }
                          
                          function finishScript(){
                          	assignEnums();
                          }
                          
                          // Add the saved IDs to the rooms/functions
                          function assignEnums(){
                           if(arEnum.length == 0 || arId.length == 0){
                                return;
                           }
                          
                           if(arEnum.length != arId.length){
                                log('Arrays have different size','error');
                                return;
                           }
                           let mapEnumId = new Map();
                           
                           for(let i=0;i < arEnum.length; i++){
                               let enu = arEnum[i];
                               let id = arId[i];
                               if(existsObject(id)){
                              	 let obj = getObject(enu)
                              	 let members;
                              	 if(!mapEnumId.has(enu)){
                              		 members = obj.common.members;
                              		 mapEnumId.set(enu,members);
                              	 }
                              	 else
                              		 members = mapEnumId.get(enu);    
                              	 if(!members.includes(id)){
                              		  log("Adding " + id + " to " + enu);
                              		  members.push(id);
                              	 }	      
                               }
                               else
                                   log('Can not find Alias ' + id,'error');
                           }
                            
                            function setMembers(members,enu,map){
                                let obj = getObject(enu);
                                obj.common.members = members;
                                setObject(enu,obj);
                            }
                            mapEnumId.forEach(setMembers);
                          }
                          

                          Hier noch die Objekt-Definition: ( Ich hoffe es ist die richtige das gibt es ja zu jedem Datenpunkt eine ....

                          {
                            "type": "channel",
                            "common": {
                              "name": "alias.0.Flur.Multisensor.Aeotec_7"
                            },
                            "_id": "alias.0.Flur.Multisensor.Aeotec_7",
                            "native": {},
                            "from": "system.adapter.admin.0",
                            "user": "system.user.admin",
                            "ts": 1698686702683,
                            "acl": {
                              "object": 1636,
                              "owner": "system.user.admin",
                              "ownerGroup": "system.group.administrator"
                            }
                          }
                          
                          haus-automatisierungH Offline
                          haus-automatisierungH Offline
                          haus-automatisierung
                          Developer Most Active
                          schrieb am zuletzt editiert von haus-automatisierung
                          #13

                          @flopsi sagte in Error im admin.0 [Alias subscription error]:

                          Versteh nicht was ich umdrehen soll ?

                          Statt

                          createAlias('zwave2.0.Node_065.Multilevel_Sensor.illuminance', 'Flur.Multisensor.Aeotec_7.Lux');
                          

                          muss es so aussehen:

                          createAlias('Flur.Multisensor.Aeotec_7.Lux', 'zwave2.0.Node_065.Multilevel_Sensor.illuminance');
                          

                          dein Script lese ich mir jetzt nicht komplett durch

                          @flopsi sagte in Error im admin.0 [Alias subscription error]:

                          Hier noch die Objekt-Definition:

                          Ja, und da fehlt die ID, auf welcher sich der Alias beziehen soll. Daher die Fehler.

                          🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                          🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                          📚 Meine inoffizielle ioBroker Dokumentation

                          1 Antwort Letzte Antwort
                          0
                          • F Flopsi

                            @haus-automatisierung sagte in Error im admin.0 [Alias subscription error]:

                            createAlias

                            Versteh nicht was ich umdrehen soll ? Kannst du mir ein Beispiel zeigen ?

                            Ich erstelle all meine Alias nach dem Schema nie probleme gehabt erst seit den neuen Sensoren...

                            Ich nutze das folgendes Skript für:

                            /**************************************************************
                            Github - https://github.com/xCruziX/ioBroker-Creating-Alias/blob/master/CreateAlias.js
                            				Changelog
                            Version 1.1.3
                              - use callbacks in alias-path
                            Version 1.1.2
                              - fix log message 'Created Alias-Path '
                            Version 1.1.1
                              - Bugfixing, clean functions
                            Version 1.1.0
                              - added function for cleaning enums
                            Version 1.0.6
                              - use callback functions for safety call
                            Version 1.0.5
                              - decrease timeout assing enum 
                            Version 1.0.4
                              - Bugfixing array id lenght
                            Version 1.0.3
                              - Githublink 
                            Version 1.0.2
                              - existsObject for Alias in the timeout
                              - remove lowerCase enum
                              - improved logs
                            Version 1.0.1
                              - Rooms and functions casesensitive
                            Version 1.0
                            **************************************************************/
                            
                            /**************************************
                            		Flags /
                            		Variablen
                            ***************************************/
                            
                            // typeAlias = 'boolean'; // oder 'number'
                            // read = "val == 'Ein' ? true : false"; // Erkennung "Aus" --> false erfolgt automatisch  
                            // write = "val ? 'Ein' : 'Aus'";
                            // nameAlias = 'Licht Haustür';
                            // role = 'switch';
                            // desc = 'per Script erstellt';
                            // min = 0; // nur Zahlen
                            // max = 100; // nur Zahlen
                            // unit = '%'; // nur für Zahlen
                            // states = {0: 'Aus', 1: 'Auto', 2: 'Ein'}; // Zahlen (Multistate) oder Logikwert (z.B. Aus/Ein)
                             
                            let bCreateAliasPath = false;  // If this flag is true, each folder is created seperately so rooms and functions can be assigned.
                            
                            /*
                            Requirements: bCreateAliasPath == true
                            If this flag is true, existing folders in the path will be converted so rooms and functions can be assigned.
                            */
                            let bConvertExistingPath = false;
                            
                            /**********************************************************
                            	Don't change anything from here /
                            	Ab hier nichts verändern
                            **********************************************************/
                            
                            let arEnum = [];
                            let arId = [];
                            let timeoutAssignEnum;
                            function createAlias(idSrc, idDst,raum, gewerk,typeAlias, read, write, nameAlias, role, desc, min, max, unit, states) {
                              if(!idDst.includes('alias.0.'))
                                  idDst = 'alias.0.' + idDst;
                              if(!existsObject(idSrc))
                              {
                                  log('Source-Id ' + idSrc +' does not exists.','warn');
                                  return;
                              }
                              
                              // Create the object Path for alias id, 
                              // so you can assign rooms and function to the parents
                              var createAliasPath = (id) => {
                                   if(bCreateAliasPath){
                                        let lisMergedIds = [];
                                        let mergedId = 'alias.0';
                                        id = id.replace(mergedId + '.', ''); // Remove prefix alias so it will not be changed
                                        let split = id.split('.'); 
                                        for(let i=0;i<split.length-1;i++){
                                            mergedId += '.' + split[i];
                                            lisMergedIds.push(mergedId);
                                        }
                                        
                                        function path(){
                                            if(lisMergedIds.length == 0) {// Zu Ende erstellt
                                                alias();
                                                return;
                                            }
                                            let tmpId = lisMergedIds[0];
                                            lisMergedIds.splice(0,1); // entferne element
                                            if(!existsObject(tmpId) || bConvertExistingPath){ // not exists
                                                let obj;
                                                if(existsObject(tmpId))
                                                    obj = getObject(tmpId);
                                                else
                                                    obj = {};
                            
                                                if(obj.type == undefined || obj.type != 'meta')
                                                    obj.type = 'meta';
                                                if(obj.common == undefined || obj.common != {})
                                                    obj.common = {};
                                                if(obj.common.type == undefined || obj.common.type != 'meta.folder')
                                                    obj.common.type = 'meta.folder';
                                                if(obj.common.desc == undefined || obj.common.desc != 'createAliasPath')
                                                    obj.common.desc = 'createAliasPath';
                                                if(obj.common.def == undefined || obj.common.def != false)
                                                    obj.common.def = false;
                                                if(obj.native == undefined || obj.native != {})
                                                    obj.native = {};
                            
                                                
                                                setObject(tmpId, obj, (err) =>{
                                                    if(!err){
                                                        log('Created Alias-Path ' + tmpId);
                                                        path();
                                                    }
                                                    else
                                                        log('Error creating alias-path','error');
                                                });
                                            }
                                        }
                                        path();
                                   }
                                   else
                                     alias();
                              }
                              
                             
                                //   createAliasPath(idDst);
                              
                              function alias(){
                                  // Create alias object
                                  
                                    if(!existsObject(idDst)){
                                        let obj = {};
                                        obj.type = 'state';
                                        obj.common = getObject(idSrc).common;
                                        obj.common.alias = {};
                                        obj.common.alias.id = idSrc;
                                        if(typeAlias !== undefined) 
                                            obj.common.type = typeAlias;
                                        if(obj.common.read !== undefined) 
                                            obj.common.alias.read = read;
                                        if(obj.common.write !== undefined) 
                                            obj.common.alias.write = write;
                                        if(nameAlias !== undefined) 
                                            obj.common.name = nameAlias;
                                        if(role !== undefined) 
                                            obj.common.role = role;
                                        if(desc !== undefined) 
                                            obj.common.desc = desc;
                                        if(min !== undefined) 
                                            obj.common.min = min;
                                        if(max !== undefined) 
                                            obj.common.max = max;
                                        if(unit !== undefined) 
                                            obj.common.unit = unit;
                                        if(states !== undefined) 
                                            obj.common.states = states;
                            
                                        obj.native = {};
                                        obj.common.custom = []; // Damit die Zuordnung zu iQontrol, Sql etc. nicht übernommen wird
                                        log('Created Alias-State ' + idDst);
                                        setObject(idDst, obj,(err) =>{ 
                                            if(!err)
                                                startAttach(); 
                                            else
                                                log('Error creating-alias','error');
                                        });
                                    }
                                    else
                                        startAttach();
                              }
                              
                              
                              // Save ID and Enum (room or function)
                              var attach = (id, enu,value) => {
                                  if(id.length == 0){
                                      log('ID has lenght 0, can not attach to enum','warn');
                                      return;
                                  }
                                  if(value.length == 0){
                                      log('Value has lenght 0','warn');
                                      return;
                                  }
                                
                                  let sEnuId = 'enum.' + enu + '.' + value;
                                  if(enu.length > 0 && existsObject(sEnuId)) 
                                  {
                                      let obj = getObject(sEnuId)
                                      let members = obj.common.members;
                                      if(!members.includes(id)){
                                          arEnum.push(sEnuId);
                                          arId.push(id);
                                      }
                                  }
                                  else
                               	      log('Can not find enum ' + sEnuId,'warn');
                              }
                             
                             function startAttach(){
                                let bRoom = raum !== undefined && raum.length > 0;
                                let bGewerk = gewerk !== undefined && gewerk.length > 0;
                                
                                if(bRoom)
                                    attach(idDst,'rooms',raum);
                                if(bGewerk)
                                    attach(idDst,'functions',gewerk);
                                if(bRoom || bGewerk){
                                        if(timeoutAssignEnum){
                                            clearTimeout(timeoutAssignEnum);
                                            timeoutAssignEnum = null;
                                        }
                                        timeoutAssignEnum = setTimeout(finishScript,100);
                                }
                             }
                             
                              createAliasPath(idDst);
                            }
                            
                            function finishScript(){
                            	assignEnums();
                            }
                            
                            // Add the saved IDs to the rooms/functions
                            function assignEnums(){
                             if(arEnum.length == 0 || arId.length == 0){
                                  return;
                             }
                            
                             if(arEnum.length != arId.length){
                                  log('Arrays have different size','error');
                                  return;
                             }
                             let mapEnumId = new Map();
                             
                             for(let i=0;i < arEnum.length; i++){
                                 let enu = arEnum[i];
                                 let id = arId[i];
                                 if(existsObject(id)){
                                	 let obj = getObject(enu)
                                	 let members;
                                	 if(!mapEnumId.has(enu)){
                                		 members = obj.common.members;
                                		 mapEnumId.set(enu,members);
                                	 }
                                	 else
                                		 members = mapEnumId.get(enu);    
                                	 if(!members.includes(id)){
                                		  log("Adding " + id + " to " + enu);
                                		  members.push(id);
                                	 }	      
                                 }
                                 else
                                     log('Can not find Alias ' + id,'error');
                             }
                              
                              function setMembers(members,enu,map){
                                  let obj = getObject(enu);
                                  obj.common.members = members;
                                  setObject(enu,obj);
                              }
                              mapEnumId.forEach(setMembers);
                            }
                            

                            Hier noch die Objekt-Definition: ( Ich hoffe es ist die richtige das gibt es ja zu jedem Datenpunkt eine ....

                            {
                              "type": "channel",
                              "common": {
                                "name": "alias.0.Flur.Multisensor.Aeotec_7"
                              },
                              "_id": "alias.0.Flur.Multisensor.Aeotec_7",
                              "native": {},
                              "from": "system.adapter.admin.0",
                              "user": "system.user.admin",
                              "ts": 1698686702683,
                              "acl": {
                                "object": 1636,
                                "owner": "system.user.admin",
                                "ownerGroup": "system.group.administrator"
                              }
                            }
                            
                            haus-automatisierungH Offline
                            haus-automatisierungH Offline
                            haus-automatisierung
                            Developer Most Active
                            schrieb am zuletzt editiert von
                            #14

                            @flopsi sagte in Error im admin.0 [Alias subscription error]:

                            Ich nutze das folgendes Skript für:

                            Okay, ich hab es mir nun doch angeschaut und frage mich, was der Sinn von diesem Script ist. Das kann der JavaScript-Adapter doch von Haus aus?

                            https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#createalias

                            Wenn Du eigene Funktionen definierst (und diese auch noch genauso nennst, wie Standard-Funktionen im JavaScript-Adapter), dann wäre das schon eine Info im Ausgangspost wert :)

                            🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                            🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                            📚 Meine inoffizielle ioBroker Dokumentation

                            F 1 Antwort Letzte Antwort
                            0
                            • haus-automatisierungH haus-automatisierung

                              @flopsi sagte in Error im admin.0 [Alias subscription error]:

                              Ich nutze das folgendes Skript für:

                              Okay, ich hab es mir nun doch angeschaut und frage mich, was der Sinn von diesem Script ist. Das kann der JavaScript-Adapter doch von Haus aus?

                              https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#createalias

                              Wenn Du eigene Funktionen definierst (und diese auch noch genauso nennst, wie Standard-Funktionen im JavaScript-Adapter), dann wäre das schon eine Info im Ausgangspost wert :)

                              F Offline
                              F Offline
                              Flopsi
                              schrieb am zuletzt editiert von
                              #15

                              @haus-automatisierung

                              ich habe das Skript einfach nur kopiert .....

                              creates Alias ......
                              

                              die Alias erstellt und mich dann auf die Alias Datenpunkte bezogen.

                              Wie machst du das denn mit den Alias ?

                              haus-automatisierungH 1 Antwort Letzte Antwort
                              0
                              • F Flopsi

                                @haus-automatisierung

                                ich habe das Skript einfach nur kopiert .....

                                creates Alias ......
                                

                                die Alias erstellt und mich dann auf die Alias Datenpunkte bezogen.

                                Wie machst du das denn mit den Alias ?

                                haus-automatisierungH Offline
                                haus-automatisierungH Offline
                                haus-automatisierung
                                Developer Most Active
                                schrieb am zuletzt editiert von
                                #16

                                @flopsi Manuell über den Geräte-Adapter erstellen

                                Aber das löst ja dein Problem nicht. Jedenfalls erstellt dein Script den Alias Datenpunkt nicht korrekt. Würde ich nicht mehr verwenden, wenn der JavsScript Adapter das direkt mitbringt.

                                🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                                🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                                📚 Meine inoffizielle ioBroker Dokumentation

                                F 1 Antwort Letzte Antwort
                                0
                                • haus-automatisierungH haus-automatisierung

                                  @flopsi Manuell über den Geräte-Adapter erstellen

                                  Aber das löst ja dein Problem nicht. Jedenfalls erstellt dein Script den Alias Datenpunkt nicht korrekt. Würde ich nicht mehr verwenden, wenn der JavsScript Adapter das direkt mitbringt.

                                  F Offline
                                  F Offline
                                  Flopsi
                                  schrieb am zuletzt editiert von Flopsi
                                  #17

                                  @haus-automatisierung

                                  Problem erscheint schon zwei Tage nicht mehr

                                  habe folgendes geändert:

                                  createAlias('Flur.Multisensor.Aeotec_7.Lux', 'zwave2.0.Node_065.Multilevel_Sensor.illuminance'); 
                                  

                                  ich habe diesen Texteil gelöscht

                                  .Aeotec_7
                                  

                                  so sieht es jetzt aus:

                                  createAlias('Flur.Multisensor.Lux', 'zwave2.0.Node_065.Multilevel_Sensor.illuminance'); 
                                  

                                  jetzt kommen keine Error mehr und die fehlende ID wurde auch erstellt

                                  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

                                  402

                                  Online

                                  32.6k

                                  Benutzer

                                  81.9k

                                  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