Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

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

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Entwicklung
  4. Adapterentwicklung / Object ID Baum

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    3.6k

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.5k

Adapterentwicklung / Object ID Baum

Scheduled Pinned Locked Moved Entwicklung
33 Posts 7 Posters 4.7k Views 4 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • snadorS Offline
    snadorS Offline
    snador
    wrote on last edited by
    #1

    Hallo, ich versuche mich gerade an der Adapterentwicklung und spiele ein wenig herum. Gibt es eine Funktion mit der ich den gesamten Objekt-ID Baum bekomme oder kann ich das Objekt ID Popup aus dem VIS Adapter auch in eigenen Projekten nutzen? Danke für die Info.

    1 Reply Last reply
    0
    • apollon77A Online
      apollon77A Online
      apollon77
      wrote on last edited by
      #2

      Ich habe den Thread mal in das richtige Forum geschoben.

      Kurze Antwort: ja, das geht.

      Länger muss ich sagen bin ich raus.habe es selbst noch nie gemacht. Ich weiss aber das der Cloud-Adapter in seinen Einstellungen eine State-ID mit "Selection-Dialog" nutzt. Schau doch mal rein wie es dort gemacht wurde.

      Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

      • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
      • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
      1 Reply Last reply
      0
      • snadorS Offline
        snadorS Offline
        snador
        wrote on last edited by
        #3

        Oh sehr schön, danke für die Info :-) Ich werde mir das Ganze mal anschauen. Nun ist Reverse Engineering ja nicht gerade der effizienteste Weg. Gibt es irgendwo eine grobe Anleitung der zur Verfügung stehenden Methoden / Funktionen / Klassen, was auch immer… Es muss keine runde Anleitung sein aber irgendwo ne Quelle wo grob was aufgeführt ist. Die Grund-Anleitung zur Adapterentwicklung auf Git kennen ich aber die beantwortet beispielweise obiges nicht... Ist dafür ja auch nicht da...

        1 Reply Last reply
        0
        • apollon77A Online
          apollon77A Online
          apollon77
          wrote on last edited by
          #4

          Anleitung für "Admin-UI" kenne ich selbst auch (noch) keine :-( Da sind die existierenden Adapter die beste Referenz.

          Wenn Du was schreiben möchtest sorge ich gerne für einen Platz um es für die Nachwelt aufzuheben :-)

          Beitrag hat geholfen? Votet rechts unten im Beitrag :-) https://paypal.me/Apollon77 / https://github.com/sponsors/Apollon77

          • Debug-Log für Instanz einschalten? Admin -> Instanzen -> Expertenmodus -> Instanz aufklappen - Loglevel ändern
          • Logfiles auf Platte /opt/iobroker/log/… nutzen, Admin schneidet Zeilen ab
          1 Reply Last reply
          0
          • snadorS Offline
            snadorS Offline
            snador
            wrote on last edited by
            #5

            Ok danke Dir. Wie meinst Du das? ("Wenn Du was schreiben möchtest sorge ich gerne für einen Platz um es für die Nachwelt aufzuheben").

            Ich bastele gerade an einem "Nightingale" Adapter der eine alternative, administrierbare, responsible Tablet / Smartphone Oberfläche zur Verfügung stellt. Ich habe zuerst mit einem Vis Template getestet und die Anfänge sind schon mal ganz gut. Ich habe ein eigenes Widget Set erstellt und darin eigene Widgets getestet. Allerding muss ich von der VIS zuviele Dinge per Javascript hinbiegen damit sie so funktionieren wie ich mir das vorstelle. Deshalb der Gedanke mal mit einem eigenen Adapter zu probieren.

            Allerdings schlägt hier der Aufwand natürlich massiv zu, da ich alles neu schreiben muss. Weil es an dieser Stelle ja nicht nur um ein Gerät sondern übertrieben gesprochen um alle viele in ioB integrierte Geräte geht. Ich muss halt diverse Funktioenn abbilden, die es eigentlich schoin gibt :-) Z.B. den Dialog um die Object-Ids auszuwählen… Hier wäre es sehr effizient wenn ich bestehende Dinge nutzen könnte.

            Ich selbst bin Grafiker / UX/UI Designer und versuche mich im Moment mal in der Erstellung einer Oberfläche die meinen Vorstellungen entspricht :-)

            1 Reply Last reply
            0
            • BluefoxB Offline
              BluefoxB Offline
              Bluefox
              wrote on last edited by
              #6

              Include this files:

              https://github.com/hometm/ioBroker.vcar … x.html#L24

              https://github.com/hometm/ioBroker.vcar ... x.html#L22

              https://github.com/hometm/ioBroker.vcar ... x.html#L18

              Include this function:

              https://github.com/hometm/ioBroker.vcar ... .html#L135

              and now you can open select ID dialog like here:

              https://github.com/hometm/ioBroker.vcar ... x.html#L81

              1 Reply Last reply
              0
              • snadorS Offline
                snadorS Offline
                snador
                wrote on last edited by
                #7

                @BlauerFuchs: Vielen Dank! Ich probiere das aus!

                1 Reply Last reply
                0
                • snadorS Offline
                  snadorS Offline
                  snador
                  wrote on last edited by
                  #8

                  Hallo BlueFox, so ganz hat es noch nicht funktioniert. Es kommt folgender Error (siehe Anhang). Das einbinden der socket.io.js hat den Fehler leider nicht behoben…

                  LG
                  4236_socket.jpg

                  1 Reply Last reply
                  0
                  • BluefoxB Offline
                    BluefoxB Offline
                    Bluefox
                    wrote on last edited by
                    #9

                    @snador:

                    Hallo BlueFox, so ganz hat es noch nicht funktioniert. Es kommt folgender Error (siehe Anhang). Das einbinden der socket.io.js hat den Fehler leider nicht behoben…

                    LG `
                    Ohne Code ist schwer zu sagen.

                    1 Reply Last reply
                    0
                    • snadorS Offline
                      snadorS Offline
                      snador
                      wrote on last edited by
                      #10

                      Ich hab eigentlich nur die Dinge gemacht, die Du mir vorgeschlagen hast und dann testweise mal einen click auf ein Element gelegt. Der Fehler kommt nur beim Click. Code schicke ihn heute Abend hinterher…

                      1 Reply Last reply
                      0
                      • snadorS Offline
                        snadorS Offline
                        snador
                        wrote on last edited by
                        #11

                        socket.emit schmeißt den Fehler…

                         function initSelectId (cb) { :? 
                                if (selectId) return cb(selectId);
                                socket.emit('getObjects', function (err, res) {
                                    if (!err && res) {
                                        selectId = $('#dialog-select-member').selectId('init',  {
                                            noMultiselect: true,
                                            objects: res,
                                            imgPath:       '../../lib/css/fancytree/',
                                            filter:        {type: 'state'},
                                            name:          'vcard-select-state',
                                            texts: {
                                                select:          _('Select'),
                                                cancel:          _('Cancel'),
                                                all:             _('All'),
                                                id:              _('ID'),
                                                name:            _('Name'),
                                                role:            _('Role'),
                                                room:            _('Room'),
                                                value:           _('Value'),
                                                selectid:        _('Select ID'),
                                                from:            _('From'),
                                                lc:              _('Last changed'),
                                                ts:              _('Time stamp'),
                                                wait:            _('Processing...'),
                                                ack:             _('Acknowledged'),
                                                selectAll:       _('Select all'),
                                                unselectAll:     _('Deselect all'),
                                                invertSelection: _('Invert selection')
                                            },
                                            columns: ['image', 'name', 'role', 'room']
                                        });
                                        cb && cb(selectId);
                                    }
                                });
                            }
                        
                        1 Reply Last reply
                        0
                        • snadorS Offline
                          snadorS Offline
                          snador
                          wrote on last edited by
                          #12

                          Ansonsten hab ich nur folgendes drin. Ein Klick auf ein Elemente zum testen.

                             $('#select2').click(function () {
                                      initSelectId(function (sid) {
                                          sid.selectId('show', $('#object2').val(), function (newId) {
                                              if (newId != $('#object2').val()) {
                                                  $('#object2').val(newId);
                                                  onChange();
                                              }
                                          });
                                      });
                                  });
                          
                          1 Reply Last reply
                          0
                          • snadorS Offline
                            snadorS Offline
                            snador
                            wrote on last edited by
                            #13

                            Ach so. Vielleicht sollte ich noch dazu sagen, dass ich die Funktion nicht im Backend benötige wie der vCard Adapter sondern auf einer Edit Seite im Frontend, ähnlich wie der Vis Adapter. Spielt ggf. ne Rolle bzgl. der einzubindenden Ressourcen…

                            1 Reply Last reply
                            0
                            • snadorS Offline
                              snadorS Offline
                              snador
                              wrote on last edited by
                              #14

                              Hier noch das aktuelle Testszenario:

                              /**
                               *  ioBroker.nightingale
                               *  https://github.com/ioBroker/ioBroker.nightingale
                               *
                               *  Copyright (c) 2018 Sandro Zimmermann https://github.com/xxx
                               *  License: MIT
                               *
                              */
                              
                              /* jshint browser:--undef */
                              /* jshint browser:true */
                              /* global document */
                              /* global console */
                              /* global session */
                              /* global window */
                              /* global location */
                              /* global setTimeout */
                              /* global clearTimeout */
                              /* global io */
                              /* global systemLang:true */
                              /* global systemLang */
                              /* global _ */
                              /* global can */
                              /* global storage */
                              /* global servConn */
                              /* global systemDictionary:true */
                              /* global systemDictionary */
                              /* global $ */
                              /* global translateAll */
                              /* global jQuery */
                              /* global $ */
                              /* global document */
                              /* jshint -W097 */// jshint strict:false
                              
                              'use strict';
                              
                              var selectId;
                              
                              // Dict ///////////////////////////////////////////////////
                              $.extend(systemDictionary, {
                                  'Views': {
                                  	'en': 'Views',
                                  	'de': 'Views',
                                  	'ru': 'Страницы'
                                  }
                              });
                              
                              // NGL ///////////////////////////////////////////////////
                              var ngl = {
                              
                              	version: "0.0.1",
                                  requiredServerVersion: '0.0.0',
                                  enums:        {},
                                  objects:      {},
                                  states:       {},
                                  root:         [],
                                  refresh:      false,
                                  isFirstTime:  true,
                                  conn:         servConn,
                                  editMode:     false,
                                  queueStates:  [],
                                  updateStates: [],
                                  ids:          [],
                                  user:         'admin',
                                  defaultInvisibleRoles: ['inhibit', 'button', 'action', 'timer'],
                                  defaultInvisibleNames: ['TIMER_ON', 'RELOCK_DELAY', 'OLD_VALUE', 'STATE_UNCERTAIN', 'DECISION_VALUE', 'ADJUSTING_DATA' , 'ADJUSTING_COMMAND', 'INSTALL_TEST'],
                                  ignoreIndicators: ['indicator.updates', 'indicator.state'],
                                  lastTimes:    [],
                                  activePage:   null,
                                  erasePage:    {},
                                  isMobile:     null,
                              
                                  // Init ///////////////////////////////////////////////////
                              
                                  init: function(){
                              
                                  	console.log('init');
                              
                                  	ngl.initConn();
                              
                                  	console.log(ngl.conn);
                                  	console.log(ngl.conn._socket);
                              
                                  	ngl.conn.getObjects(function (err, data) {
                                                  vis.objects = data;
                                      });
                              
                                  	$('#testfield').click(function () {
                                          ngl.initSelectId(function (sid) {
                                              sid.selectId('show', $('#testfield').val(), function (newId) {
                                                  if (newId != $('#testfield').val()) {
                                                      $('#testfield').val(newId);
                                                      onChange();
                                                  }
                                              });
                                          });
                                      });
                              
                                  },
                              
                                  // Connection ///////////////////////////////////////////////////
                              
                                  initConn: function(){
                              
                                  	ngl.conn.namespace   = 'nightingale.0';
                              	    ngl.conn._useStorage = false;
                              	    var states = [];
                              	    ngl.conn.init({
                              	        name:          		'',  			// optional - default 'vis.0'
                              	        connLink:      		'',  	// optional URL of the socket.io adapter
                              	        socketSession: 		''           				// optional - used by authentication
                              	    },{
                              	        onConnChange: function (isConnected) {
                              	            if (isConnected) {
                              	                console.log('connected');
                              	                ngl.conn.getStates(function (err, _states) {
                              	                    var count = 0;
                              	                    for (var id in _states) {
                              	                        count++;
                              	                    }
                              	                    console.log('Received ' + count + ' states.');
                              	                    states = _states;
                              	                });
                              	            } else {
                              	                console.log('disconnected');
                              	            }
                              	        },
                              	        onRefresh: function () {
                              	            window.location.reload();
                              	        },
                              	        onUpdate: function (id, state) {
                              	            setTimeout(function () {
                              	                console.log('NEW VALUE of ' + id + ': ' + JSON.stringify(state));
                              	                states[id] = state;
                              	            }, 0);
                              	        },
                              	        onError: function (err) {
                              	            window.alert(_('Cannot execute %s for %s, because of insufficient permissions', err.command, err.arg), _('Insufficient permissions'), 'alert', 600);
                              	        }
                              	    });
                              
                                  },
                              
                                  // Object Tree ///////////////////////////////////////////////////
                              
                                  initSelectId: function(cb) {
                                      if (selectId) return cb(selectId);
                                      ngl.conn._socket.emit('getObjects', function (err, res) {
                                          if (!err && res) {
                                              selectId = $('#dialog-select-member').selectId('init',  {
                                                  noMultiselect: true,
                                                  objects: res,
                                                  imgPath:       '../../lib/css/fancytree/',
                                                  filter:        {type: 'state'},
                                                  name:          'vcard-select-state',
                                                  texts: {
                                                      select:          _('Select'),
                                                      cancel:          _('Cancel'),
                                                      all:             _('All'),
                                                      id:              _('ID'),
                                                      name:            _('Name'),
                                                      role:            _('Role'),
                                                      room:            _('Room'),
                                                      value:           _('Value'),
                                                      selectid:        _('Select ID'),
                                                      from:            _('From'),
                                                      lc:              _('Last changed'),
                                                      ts:              _('Time stamp'),
                                                      wait:            _('Processing...'),
                                                      ack:             _('Acknowledged'),
                                                      selectAll:       _('Select all'),
                                                      unselectAll:     _('Deselect all'),
                                                      invertSelection: _('Invert selection')
                                                  },
                                                  columns: ['image', 'name', 'role', 'room']
                                              });
                                              cb && cb(selectId);
                                          }
                                      });
                                  }
                              
                                  // Helpers ///////////////////////////////////////////////////
                              
                              };
                              
                              // Ready ///////////////////////////////////////////////////
                              (function ($) {
                                  $(document).ready(function () {
                                      ngl.init();
                                  });
                              })(jQuery);
                              
                              
                                  <title>Titel</title>
                              
                              ### Nightingale Adapter
                              
                              
                              1 Reply Last reply
                              0
                              • snadorS Offline
                                snadorS Offline
                                snador
                                wrote on last edited by
                                #15

                                So, ich hab mal den Code oben drüber aktualisiert. Sorry aber ich blicke insgesamt noch nicht wirklich durch, deshalb die ganze Anfängerfragen. Ich versuche gerade im Adapter "Frontend" (www) eine Seite zu erstellen (ähnlich Vis Edit) die eine Connection erstellt und SocketIO zum Laufen bringt. Danach möchte ich gerne den Object Baum holen. Nur mal so für den Anfang. Vielleicht versteh ich es irgendwann :-) Ich hab mir die grundsätzliche Vorgehensweise in diversen Adaptern abgeschaut.

                                Nun zu meinen Fragen.

                                1: Muss ich die Connection im www überhaupt noch initialisieren oder steht die schon wenn der Adapter läuft? Ist es so halbweg korrekt?

                                2: Die Connection scheint erfolgreich zu laufen aber es kommt die Meldung "socket.io not initialized" (Meldung kommt erst wenn ngl.conn.getObjects aufgerufen wird). Wie mache ich das und muss ich überhaupt?

                                3: In der Funktion initSelectId bringt der Aufruf socket.emit() den weiter oben erwähnten Fehler aber auch ngl.conn._socket.emit() liefert zurück das _socket logischerweise null ist :-) Führe ich auf Punkt [2] zurück…

                                4: Ist mein grober Ansatz überhaupt korrekt?

                                Vielleicht kann einer der Wissenden mal drüber schauen und dem Noob etwas auf die Sprünge helfen.

                                Vielen Dank!
                                4236_console.jpg

                                1 Reply Last reply
                                0
                                • snadorS Offline
                                  snadorS Offline
                                  snador
                                  wrote on last edited by
                                  #16

                                  Neuer Stand: Ich habe den socket.io Adapter installiert und läuft es erst einmal. Nun fragen ich mich allerdings warum andere Adapter auch laufen ohne das der Socket.io Adapter installiert war? Gibt es noch eine andere (eventuell günstigere) Variante ohne den socket.io Adapter zu installieren? Und ist es normal das in der Console minutenlang alle gefundenen Objekte durchlaufen?

                                  Fragen über Fragen, sorry :-)

                                  1 Reply Last reply
                                  0
                                  • AlCalzoneA Offline
                                    AlCalzoneA Offline
                                    AlCalzone
                                    Developer
                                    wrote on last edited by
                                    #17

                                    @snador:

                                    Gibt es noch eine andere (eventuell günstigere) Variante ohne den socket.io Adapter zu installieren? `
                                    Möglicherweise mit dem Web-Adapter und seiner integrierten socket.io-Instanz.

                                    Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

                                    1 Reply Last reply
                                    0
                                    • snadorS Offline
                                      snadorS Offline
                                      snador
                                      wrote on last edited by
                                      #18

                                      Ich habe jetzt noch was anderes ausprobiert :-) Ich habe mir aus einem anderen Adapter den Part "_socket/info.js" herauskopiert und eingebunden und den socket.io Adapter wieder deinstalliert. Und siehe da es geht :-) Kann mir Jemand erklären warum und ob die Vorgehensweise so einigermaßen korrekt ist.

                                      
                                          <title>Titel</title>
                                      
                                      

                                      Aber noch eine andere Frage: Muss das so sein, dass in der Console unablässig die Objekte laufen? Siehe Anhang:
                                      4236_console.jpg

                                      1 Reply Last reply
                                      0
                                      • simatecS Online
                                        simatecS Online
                                        simatec
                                        Developer Most Active
                                        wrote on last edited by
                                        #19

                                        Ich krame hier mal den alten Thread wieder raus.
                                        Aktuell habe ich ein vergleichbares Problem.

                                        Ich bekomme die Object-ID Dialog auf biegen und brechen nicht aufgerufen.
                                        Hier mal der aktuelle Stand vom Github mit meinen Versuchen.
                                        https://github.com/simatec/ioBroker.shuttercontrol/blob/master/admin/index_m.html

                                        Hab keine Idee, was ich noch probieren kann.

                                        • Besuche meine Github Seite
                                        • Beitrag hat geholfen oder willst du mich unterstützen
                                        • HowTo Restore ioBroker
                                        1 Reply Last reply
                                        0
                                        • simatecS Online
                                          simatecS Online
                                          simatec
                                          Developer Most Active
                                          wrote on last edited by
                                          #20

                                          edit: Die Dialogbox mit Oject-Baum öffnet jetzt.
                                          Wie man allerdings die ausgewählte ID nun in die neu angelegte Tabellenzeile bekommt, erschließt sich mir garnicht.
                                          Gibt es irgendwo eine Doku zu den Aufbau der Tabellen?

                                          • Besuche meine Github Seite
                                          • Beitrag hat geholfen oder willst du mich unterstützen
                                          • HowTo Restore ioBroker
                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          690

                                          Online

                                          32.7k

                                          Users

                                          82.4k

                                          Topics

                                          1.3m

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

                                          • Don't have an account? Register

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