Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Error/Bug
    4. Error im admin.0 [Alias subscription error]

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Error im admin.0 [Alias subscription error]

    This topic has been deleted. Only users with topic management privileges can see it.
    • F
      Flopsi @Thomas Braun last edited by

      @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 Braun 1 Reply Last reply Reply Quote 0
      • Thomas Braun
        Thomas Braun Most Active @Flopsi last edited by

        @flopsi

        Siehste. 18.18.2 ist aktuell angesagt...

        F 1 Reply Last reply Reply Quote 0
        • F
          Flopsi @Thomas Braun last edited by

          @thomas-braun

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

          Thomas Braun 1 Reply Last reply Reply Quote 0
          • Thomas Braun
            Thomas Braun Most Active @Flopsi last edited by

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

            F 1 Reply Last reply Reply Quote 0
            • F
              Flopsi @Thomas Braun last edited by

              @thomas-braun

              Zu meinem eigentlichen Problem hast du keine Idee ?

              Thomas Braun 1 Reply Last reply Reply Quote 0
              • Thomas Braun
                Thomas Braun Most Active @Flopsi last edited by

                @flopsi

                Dann hätte ich dazu was geschrieben.

                1 Reply Last reply Reply Quote 0
                • haus-automatisierung
                  haus-automatisierung Developer Most Active @Flopsi last edited by

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

                  F 1 Reply Last reply Reply Quote 0
                  • F
                    Flopsi @haus-automatisierung last edited by

                    @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-automatisierung 1 Reply Last reply Reply Quote 0
                    • haus-automatisierung
                      haus-automatisierung Developer Most Active @Flopsi last edited by 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 1 Reply Last reply Reply Quote 0
                      • F
                        Flopsi @haus-automatisierung last edited by

                        @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-automatisierung 2 Replies Last reply Reply Quote 0
                        • haus-automatisierung
                          haus-automatisierung Developer Most Active @Flopsi last edited by haus-automatisierung

                          @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.

                          1 Reply Last reply Reply Quote 0
                          • haus-automatisierung
                            haus-automatisierung Developer Most Active @Flopsi last edited by

                            @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 1 Reply Last reply Reply Quote 0
                            • F
                              Flopsi @haus-automatisierung last edited by

                              @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-automatisierung 1 Reply Last reply Reply Quote 0
                              • haus-automatisierung
                                haus-automatisierung Developer Most Active @Flopsi last edited by

                                @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 1 Reply Last reply Reply Quote 0
                                • F
                                  Flopsi @haus-automatisierung last edited by Flopsi

                                  @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 Reply Last reply Reply Quote 0
                                  • First post
                                    Last post

                                  Support us

                                  ioBroker
                                  Community Adapters
                                  Donate

                                  839
                                  Online

                                  31.8k
                                  Users

                                  79.9k
                                  Topics

                                  1.3m
                                  Posts

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