Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Adapter Speedport

    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

    Adapter Speedport

    This topic has been deleted. Only users with topic management privileges can see it.
    • C
      cybertron last edited by

      Hallo Pix,

      ich würde jetzt fast sagen… "Du bist mein Held" 🙂

      DANKE...

      Ich werd jetzt mal die nächsten Abende abtauchen und das Ganze mal versuchen aufzuarbeiten.

      Fällt Dir eventuell noch ein Weg ein, den Json-String direkt aus der Datei auszulesen?

      in jeder der erzeugten Textdateien ist ja jeweil nur ein für diese Abfrage relevanter Json-String drin.

      Das wäre eventuell für später auch interessant, damit man auswählen kann, welche Infozweige man lesen will.

      (denk da so an einen Adapter, obwohl ich jetzt erstmal anfangen muss mich mit js zu befassen ;)) )

      Gruss

      Silvio

      1 Reply Last reply Reply Quote 0
      • C
        cybertron last edited by

        Hallo zusammen,

        inzwischen bin ich mit meinem minimalen Entwicklungswissen schon ein Stück weiter gekommen.

        Aber so langsam komme ich an meine Grenzen.

        Ich habe das Ganze ersteinmal als Script begonnen. Die Abfrage der Rubrik lte-info funktioniert soweit schon mal.

        Wenn ich die Rubrik dsl ebenfals auf true setze hakelt es irgendwie zwischendurch immer mal.

        /* SpeedPort einlesen
        
        SpeedPort Hybrid - Status Daten in JS Variablen schreiben
        
        erstellt: 09.09.2016 von Cybertron
        */
        
        var logging = false;
        var instanz = 'javascript.0';  instanz = instanz + '.';
        var pfad    =     'Status.SpeedPortHybrid.';
        var l33tport_pfad = '/home/pi/l33tport/l33tport.js';
        var cronStr = "*/1 * * * *";
        
        /*
        Endpoints lt https://github.com/melle/l33tport
        
        dsl              DSL connection status and line information');
        interfaces       Network interfaces');
        arp              ARP table');
        session          PPPoE Session');
        dhcp_client      DHCP client');
        dhcp_server      DHCP server, includes DHCP leases ');
        ipv6             IPv6 Router Advertisement');
        dns              DNS server and cache information');
        routing          Routing table');
        igmp_proxy       IGMP Proxy');
        igmp_snooping    IGMP Snooping Table');
        wlan             WLAN status and information');
        module           Software version information');
        memory           Memory and CPU utilization');
        speed            Speed dial');
        webdav           WebDAV URL');
        bonding_client   Bonding HA client');
        bonding_tunnel   Bonding tunnel');
        filterlist       Filter list table');
        bonding_tr181    Bonding TR-181');
        lteinfo          LTE information');
        Status           System information (no login needed)');
        SecureStatus     Secure system information (login needed)');
        Overview         General status information, i.e. tunnel status');
        modules          ');
        Abuse            trusted SMTP servers configuration');
        DECTStation      DECT configuration');
        hsdelmobil       DECT handset status');
        LAN              LAN status (DHCP assigned IPs ect.)');
        
        zusätzliche Endpoints lt https://github.com/Stricted/speedport-hybrid-php-api
        
        Connect
        WLANBasic
        WLANAccess
        NASLight
        INetIP
        FilterAndTime
        Portforwarding
        PhoneBook
        PhoneCalls
        SystemMessages
        DynDNS
        
        */
        // ############################################################################
        // #             						Variablen												#
        // ############################################################################
        
        var selection_dsl = false;
        var selection_interfaces = false;
        var selection_arp = false;
        var selection_session = false;
        var selection_dhcp_client = false;
        var selection_dhcp_server = false;
        var selection_ipv6 = false;
        var selection_dns = false;
        var selection_routing = false;
        var selection_igmp_proxy = false;
        var selection_igmp_snooping = false;
        var selection_wlan = false;
        var selection_module = false;
        var selection_memory = false;
        var selection_speed = false;
        var selection_webdav = false;
        var selection_bonding_client = false;
        var selection_bonding_tunnel = false;
        var selection_filterlist = false;
        var selection_bonding_tr181 = false;
        var selection_lteinfo = true;
        var selection_Status = false;
        var selection_SecureStatus = false;
        var selection_Overview = false;
        var selection_modules = false;
        var selection_Abuse = false;
        var selection_DECTStation = false;
        var selection_hsdelmobil = false;
        var selection_LAN = false;
        //
        // var selection_PhoneCalls = true;
        //
        var dpWrite_section = "";
        var actual_section = "";
        
        // ################################################################
        // #  					Datenpunkte erstellen								#
        // ################################################################
            if (selection_lteinfo === true) {
                // {"imei":"864230023577834","imsi":"262014944528183","device_status":"Attached","card_status":"SIM OK","antenna_mode":"Antennal set to external","phycellid":"72","cellid":"28385538","rsrp":"-85","rsrq":"-10","service_status":"Effective service","tac":"13500"}
        
        		//		createState(instanz + pfad + 'LTE-Info.' + 'dsl_status',,{name: 'DSL Status', desc: 'DSL-Satus: online-offline', type: 'boolean'});
        		createState(instanz + pfad + 'LTE-Info.' + 'rsrpQual',{name: 'RSRP-Qualitaet', desc: 'Qualität des RSRP-Wertes', type: 'number'});
        		createState(instanz + pfad + 'LTE-Info.' + 'rsrqQual',{name: 'RSRQ-Qualitaet', desc: 'Qualität des RSRQ-Wertes', type: 'number'});
        		createState(instanz + pfad + 'LTE-Info.' + 'IMEI',{name: 'IMEI', desc: 'IMEI der Sim-Karte', type: 'string'});
        		createState(instanz + pfad + 'LTE-Info.' + 'IMSI',{name: 'IMSI', desc: 'IMSI der Sim-Karte', type: 'string'});
        		createState(instanz + pfad + 'LTE-Info.' + 'Device-Status',{name: 'Device-Status', desc: 'Device-Status', type: 'string'});
        		createState(instanz + pfad + 'LTE-Info.' + 'Card-Status',{name: 'Card-Status', desc: 'Status der Sim-Karte', type: 'string'});
        		createState(instanz + pfad + 'LTE-Info.' + 'Antenna-Mode',{name: 'Antenna-Mode', desc: 'Antennen-Mode', type: 'string'});
        		createState(instanz + pfad + 'LTE-Info.' + 'phycellid',{name: 'phycellid', desc: 'phycellid', type: 'string'});
        		createState(instanz + pfad + 'LTE-Info.' + 'cellid',{name: 'cellid', desc: 'cellid', type: 'string'});
        		createState(instanz + pfad + 'LTE-Info.' + 'rsrp',{name: 'rsrp', desc: 'rsrp', type: 'string'});
        		createState(instanz + pfad + 'LTE-Info.' + 'rsrq',{name: 'rsrq', desc: 'rsrq', type: 'string'});
        		createState(instanz + pfad + 'LTE-Info.' + 'Service-Status',{name: 'Service-Status', desc: 'Service-Status', type: 'string'});
        		createState(instanz + pfad + 'LTE-Info.' + 'TAC',{name: 'TAC', desc: 'TAC', type: 'string'});
        	}
        
            if (selection_dsl === true) {
        
        		createState(instanz + pfad + 'DSL.Connection.' + 'dsl_operaing_mode',{name: 'Operating-Mode', desc: 'Art des DSL-Anschlusses', type: 'string'});
        		createState(instanz + pfad + 'DSL.Connection.' + 'path_mode',{name: 'Path-Mode', desc: 'Path-Mode', type: 'string'});
        		createState(instanz + pfad + 'DSL.Connection.' + 'state',{name: 'State', desc: 'Status', type: 'string'});
        		createState(instanz + pfad + 'DSL.Connection.' + 'training_results',{name: 'Training-Results', desc: 'Training-Results', type: 'string'});
        		createState(instanz + pfad + 'DSL.Connection.' + 'mode_lo',{name: 'Mode_Lo', desc: 'Mode_Lo', type: 'string'});
        		createState(instanz + pfad + 'DSL.Connection.' + 'vpi_vci',{name: 'VPI-VCI', desc: 'VPI-VCI', type: 'string'});
        		//
        		createState(instanz + pfad + 'DSL.Line.' + 'uactual',{name: 'uactual', desc: 'Aktuelle Upload-Rate', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'dactual',{name: 'dactual', desc: 'Aktuelle Download-Rate', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'uattainable',{name: 'uattainable', desc: 'uattainable', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'dattainable',{name: 'dattainable', desc: 'dattainable', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'uSNR',{name: 'uSNR', desc: 'uSNR', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'dSNR',{name: 'dSNR', desc: 'dSNR', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'uSignal',{name: 'uSignal', desc: 'uSignal', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'dSignal',{name: 'dSignal', desc: 'dSignal', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'uLine',{name: 'uLine', desc: 'uLine', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'dLine',{name: 'dLine', desc: 'dLine', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'uFEC_size',{name: 'uFEC_size', desc: 'uFEC_size', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'dFEC_size',{name: 'dFEC_size', desc: 'dFEC_size', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'uCodeword',{name: 'uCodeword', desc: 'uCodeword', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'dCodeword',{name: 'dCodeword', desc: 'dCodeword', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'uInterleave',{name: 'uInterleave', desc: 'uInterleave', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'dInterleave',{name: 'dInterleave', desc: 'dInterleave', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'uCRC',{name: 'uCRC', desc: 'uCRC', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'dCRC',{name: 'dCRC', desc: 'dCRC', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'uHEC',{name: 'uHEC', desc: 'uHEC', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'dHEC',{name: 'dHEC', desc: 'dHEC', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'uFEC',{name: 'uFEC', desc: 'uFEC', type: 'string'});
        		createState(instanz + pfad + 'DSL.Line.' + 'dFEC',{name: 'dFEC', desc: 'dFEC', type: 'string'});
        	    //
            }
        
        // ######################################################################
        // #               Abholen der Daten vom SpeedPort								#
        // ######################################################################
        function getData() {
            if (selection_lteinfo === true) {
                log('Daten für LTE-Info werden abgefragt: ');
        		dpWrite_section = 'lteinfo';
        		exec("node " + l33tport_pfad + " -o json -f lteinfo", function(err, stdout, stderr) {
            	if (err) {
              	    log(stderr,'error');
              	return;
            	}
            	log('Rückgabewert: ' + stdout);
            	writeDP(stdout,dpWrite_section);
            	dpWrite_section='';
        		});
        	}
        	if (selection_dsl === true) {
                log('Daten für DSL werden abgefragt: ');
        		dpWrite_section = 'dsl';
        		exec("node " + l33tport_pfad + " -o json -f dsl", function(err, stdout, stderr) {
            	if (err) {
              	    log(stderr,'error');
              	return;
            	}
            	log('Rückgabewert: ' + stdout);
        		writeDP(stdout,dpWrite_section);
        		dpWrite_section='';
        		});
        	}
        }
        
        function writeDP (jsonString,selection) {
        
           	var objects = JSON.parse(jsonString);
        	var jsonStr = jsonString; 
            log (jsonStr);
        
            if (selection === 'lteinfo') {
                var imei = objects.imei;
                var imsi = objects.imsi;
                var device_status = objects.device_status;
                var card_status = objects.card_status;
                var antenna_mode = objects.antenna_mode;
                var phycellid = objects.phycellid;
                var cellid = objects.cellid;
                var rsrp = objects.rsrp;
                var rsrq = objects.rsrq;
                var service_status = objects.service_status;
                var tac = objects.tac;
                var rsrp_qual = 0;
                var rsrq_qual = 0;
        
        		// SetState für lteinfo mit SubPfad LTE-Info
        		// setState(instanz + pfad + 'LTE-Info.' + Wertezweig,variable);
        		setState(instanz + pfad + 'LTE-Info.' + 'IMEI', imei);
        		setState(instanz + pfad + 'LTE-Info.' + 'IMSI', imsi);
        		setState(instanz + pfad + 'LTE-Info.' + 'Device-Status', device_status);
        		setState(instanz + pfad + 'LTE-Info.' + 'Card-Status', card_status);
        		setState(instanz + pfad + 'LTE-Info.' + 'Antenna-Mode', antenna_mode);
        		log('phycellid ist vom Typ: ' + typeof phycellid);
        		setState(instanz + pfad + 'LTE-Info.' + 'phycellid', phycellid);
        		setState(instanz + pfad + 'LTE-Info.' + 'cellid', cellid);
        		setState(instanz + pfad + 'LTE-Info.' + 'rsrp', rsrp);
        		setState(instanz + pfad + 'LTE-Info.' + 'rsrq', rsrq);
        		setState(instanz + pfad + 'LTE-Info.' + 'Service-Status', service_status);
        		setState(instanz + pfad + 'LTE-Info.' + 'TAC', tac);
        
            log ('RSRQ-Wert = ' + rsrq);
            rsrq = parseInt(rsrq);
            if(rsrq >= -15) rsrq_qual = 1;
            if(rsrq >= -11) rsrq_qual = 2;
            if(rsrq >= -8) rsrq_qual = 3;
            if(rsrq >= -5) rsrq_qual = 4;
            if(rsrq >= -3) rsrq_qual = 5;
            setState(instanz + pfad + 'LTE-Info.' + 'rsrqQual', rsrq_qual);
        
            // analog mit rsrp          rsrp_qual
            log ('rsrp-Wert = ' + rsrp);
            rsrp = parseInt(rsrp);
            if(rsrp >= -124) rsrp_qual = 1;
            if(rsrp >= -109) rsrp_qual = 2;
            if(rsrp >= -95) rsrp_qual =3;
            if(rsrp >= -80) rsrp_qual =4;
            if(rsrp >= -65) rsrp_qual =5;
        
            setState(instanz + pfad + 'LTE-Info.' + 'rsrpQual', rsrp_qual);
        
        	}
        
        	 if (selection === 'dsl') {
                var dsl_operaing_mode = objects.Connection.dsl_operaing_mode;
                var path_mode = objects.Connection.path_mode;
                var state = objects.Connection.state;
                var training_results = objects.Connection.training_results;
                var mode_lo = objects.Connection.mode_lo;
                var vpi_vci = objects.Connection.vpi_vci;
                //
                var uactual = objects.Line.uactual;
                var dactual = objects.Line.dactual;
                var uattainable = objects.Line.uattainable;
                var dattainable = objects.Line.dattainable;
                var uSNR = objects.Line.uSNR;
                var dSNR = objects.Line.dSNR;
                var uSignal = objects.Line.uSignal;
                var dSignal = objects.Line.dSignal;
                var uLine = objects.Line.uLine;
                var dLine = objects.Line.dLine;
                var uFEC_size = objects.Line.uFEC_size;
                var dFEC_size = objects.Line.dFEC_size;
                var uCodeword = objects.Line.uCodeword;
                var dCodeword = objects.Line.dCodeword;
                var uInterleave = objects.Line.uInterleave;
                var dInterleave = objects.Line.dInterleave;
                var uCRC = objects.Line.uCRC;
                var dCRC = objects.Line.dCRC;
                var uHEC = objects.Line.uHEC;
                var dHEC = objects.Line.dHEC;
                var uFEC = objects.Line.uFEC;
                var dFEC = objects.Line.dFEC;
        
        		// SetState für lteinfo mit SubPfad LTE-Info
        		// setState(instanz + pfad + 'LTE-Info.' + Wertezweig,variable);
        		setState(instanz + pfad + 'DSL.Connection.' + 'dsl_operaing_mode', dsl_operaing_mode);
        		setState(instanz + pfad + 'DSL.Connection.' + 'path_mode', path_mode);
        		setState(instanz + pfad + 'DSL.Connection.' + 'state', state);
        		setState(instanz + pfad + 'DSL.Connection.' + 'training_results', training_results);
        		setState(instanz + pfad + 'DSL.Connection.' + 'mode_lo', mode_lo);
        		setState(instanz + pfad + 'DSL.Connection.' + 'vpi_vci', vpi_vci);
        		//
        		setState(instanz + pfad + 'DSL.Line.' + 'uactual', uactual);
        		setState(instanz + pfad + 'DSL.Line.' + 'dactual', dactual);
        		setState(instanz + pfad + 'DSL.Line.' + 'uattainable',uattainable );
        		setState(instanz + pfad + 'DSL.Line.' + 'dattainable',dattainable );
        		setState(instanz + pfad + 'DSL.Line.' + 'uSNR', uSNR);
        		setState(instanz + pfad + 'DSL.Line.' + 'dSNR',dSNR );
        		setState(instanz + pfad + 'DSL.Line.' + 'uSignal',uSignal );
        		setState(instanz + pfad + 'DSL.Line.' + 'dSignal',dSignal );
        		setState(instanz + pfad + 'DSL.Line.' + 'uLine',uLine );
        		setState(instanz + pfad + 'DSL.Line.' + 'dLine',dLine );
        		setState(instanz + pfad + 'DSL.Line.' + 'uFEC_size', uFEC_size);
        		setState(instanz + pfad + 'DSL.Line.' + 'dFEC_size', dFEC_size);
        		setState(instanz + pfad + 'DSL.Line.' + 'uCodeword', uCodeword);
        		setState(instanz + pfad + 'DSL.Line.' + 'dCodeword', dCodeword);
        		setState(instanz + pfad + 'DSL.Line.' + 'uInterleave',uInterleave );
        		setState(instanz + pfad + 'DSL.Line.' + 'dInterleave',dInterleave );
        		setState(instanz + pfad + 'DSL.Line.' + 'uCRC',uCRC );
        		setState(instanz + pfad + 'DSL.Line.' + 'dCRC',dCRC );
        		setState(instanz + pfad + 'DSL.Line.' + 'uHEC',uHEC );
        		setState(instanz + pfad + 'DSL.Line.' + 'dHEC',dHEC );
        		setState(instanz + pfad + 'DSL.Line.' + 'uFEC',uFEC );
        		setState(instanz + pfad + 'DSL.Line.' + 'dFEC',dFEC );
        
        	}	
        }
        
        // regelmässige Wiederholungen
        // -----------------------------------------------------------------------------
        schedule(cronStr, getData);
        
        

        Da ich ja im Ursprung das alles lieber als Adapter gehabt hätte, habe ich dies im Ansatz auf Github https://github.com/ssbingo/iobroker.speedport-hybrid mal versucht anzufangen.

        Muss aber zugeben, dass ich da mangels Wissen komplett scheitere.

        Vielleicht findet sich ja jemand, der Lust und Interesse hat, da mit zu werkeln.

        Bis heute habe ich ersteinmal die Datenpunkte für die ersten 4 Rubriken definiert und die admin.html angepasst.

        Die restlichen mit l33tport machbaren Rubriken werde ich nach und nach weiter einpflegen.

        An dem eigentlichen Adapter sehe ich mich aber kläglich scheitern.

        Gruss

        Silvio

        edit: Vorschalg von paul53 in script übernommen

        1 Reply Last reply Reply Quote 0
        • paul53
          paul53 last edited by

          Die switch/case-Arie kann man verkürzen:

          log ('RSRQ-Wert = ' + rsrq);
          rsrq = parseInt(rsrq);
          var qual = 0;
          if(rsrq >= -15) qual = 1;
          if(rsrq >= -11) qual = 2;
          if(rsrq >= -8) qual = 3;
          if(rsrq >= -5) qual = 4;
          if(rsrq >= -3) qual = 5;
          setState(instanz + pfad + 'LTE-Info.' + 'rsrqQual', qual);
          
          // analog mit rsrp
          log ('rsrp-Wert = ' + rsrp);
          rsrp = parseInt(rsrp);
          qual = 0;
          if(
          ...
          setState(instanz + pfad + 'LTE-Info.' + 'rsrpQual', qual);
          
          
          1 Reply Last reply Reply Quote 0
          • C
            cybertron last edited by

            Danke

            hab den Vorschlag direkt übernommen und auch im Thread direkt mit übernommen.

            Gruss

            Silvio

            1 Reply Last reply Reply Quote 0
            • C
              cybertron last edited by

              Hallo zusammen,

              ich habe es inzwischen (dank vielem Abgucken bei anderen Adaptern) geschafft, dass ich den Adapter installieren kann und dass die später mal verfügbaren Rubriken in den Objekten angelegt werden.

              Für die ersten 4 Rubriken (lteinfo, dsl, module, bonding_tr181) werden auch die einzelnen Objekte angelegt.

              Offensichtlich habe ich aber noch einen gröberen Fehler in der main.js

              ich versuche, wie im Script bereits, das l33tport.js über exec aufzurufen.

              Im Log wird diesbezüglich nur eine Fehlermeldung ausgegeben.

              Code aus Script:

                    exec("node " + l33tport_pfad + " -o json -f lteinfo", function(err, stdout, stderr) {
                     if (err) {
                           log(stderr,'error');
                       return;
                     }
                     log('Rückgabewert: ' + stdout);
                     writeDP(stdout,dpWrite_section);
                     dpWrite_section='';
                    });
              

              Code aus Adapter (main.js)

              		exec("node " + l33tport_pfad + "l33tport.js -o json -f lteinfo", function(err, stdout, stderr) {
              		adapter.log.debug ('START: l33tport for lteinfo');
                  	if (err) {
                    	adapter.log.error(stderr,"error");
                    	return;
                  	}
                  	adapter.log.debug("Rueckgabewert: " + stdout);
                  	writeDP(stdout,dpWrite_section);
                  	dpWrite_section = "";
              		});
              

              Der Pfad ist vorher so definiert:

              var l33tport_pfad =	'/home/pi/l33tport/';
              

              Vielleicht könnte jemand mit mehr Wissen mal drüber schauen und mir helfen, wo ich den Fehler mache.

              Geht "exec" vielleicht innerhalb des Adapters so gar nicht?

              Da ich wie bereits erwähnt ganz am Anfang mit meinen Erfahrungen stehe und das Ganze rein im Editor schreibe bin ich an dieser Stelle momentan echt aufgeschmissen.

              Danke schon mal

              Gruss

              Silvio

              zu finden ist das Ganze unter https://github.com/ssbingo/iobroker.speedporthybrid

              1 Reply Last reply Reply Quote 0
              • kmxak
                kmxak Most Active last edited by

                Moin gerade über dein Thema gestolpert. Ich habe ebenfalls diesen Router.

                Anscheinend Arbeitest du aber nicht mehr an dem Adapter ist das so?

                Gruß

                Alex

                1 Reply Last reply Reply Quote 0
                • apollon77
                  apollon77 last edited by

                  @cybertron: Was ist denn genau die Fehlermeldung?

                  1 Reply Last reply Reply Quote 0
                  • kmxak
                    kmxak Most Active last edited by

                    Ich habe nun den Speedport Hybrind mittels der FHEM Anleitung und FHEM eingebunden.

                    https://forum.fhem.de/index.php/topic,54211.0.html
                    

                    ` > Nach der Definition ist das Attribut fieldnames noch unbelegt.

                    Wenn man alles auswählt wird die Readingsliste sehr, sehr lang. `

                    Ganz wichtig :lol: Es sind wirklich sehr viele Infos die eingelesen werden! Mein Browser ging nach 10 min wieder :mrgreen:

                    Ich habe aktuell nur dsl und lte info das reicht mir und es läd nun auch wieder fix 😉
                    2343_lte.jpg

                    1 Reply Last reply Reply Quote 0
                    • lobomau
                      lobomau last edited by

                      Läuft das Script soweit?

                      Was muss ich an Anpassungen vornehmen?

                      Ich hatte nur für mich den Pfad "var l33tport_pfad = '/home/pi/l33tport/l33tport.js';" angepasst. Er meckert dass Modul fehlt "l33tport.js".

                      Edit:

                      habe gerade gelesen, dass man folgendes installieren muss:

                      npm install sjcl
                      npm install commander
                      

                      @cybertron:

                      Hallo zusammen,

                      inzwischen bin ich mit meinem minimalen Entwicklungswissen schon ein Stück weiter gekommen.

                      Aber so langsam komme ich an meine Grenzen.

                      Ich habe das Ganze ersteinmal als Script begonnen. Die Abfrage der Rubrik lte-info funktioniert soweit schon mal.

                      Wenn ich die Rubrik dsl ebenfals auf true setze hakelt es irgendwie zwischendurch immer mal.

                      ! ````
                      /* SpeedPort einlesen
                      ! SpeedPort Hybrid - Status Daten in JS Variablen schreiben
                      ! erstellt: 09.09.2016 von Cybertron
                      /
                      ! var logging = false;
                      var instanz = 'javascript.0'; instanz = instanz + '.';
                      var pfad = 'Status.SpeedPortHybrid.';
                      var l33tport_pfad = '/home/pi/l33tport/l33tport.js';
                      var cronStr = "
                      /1 * * * ";
                      ! /

                      Endpoints lt https://github.com/melle/l33tport
                      ! dsl DSL connection status and line information');
                      interfaces Network interfaces');
                      arp ARP table');
                      session PPPoE Session');
                      dhcp_client DHCP client');
                      dhcp_server DHCP server, includes DHCP leases ');
                      ipv6 IPv6 Router Advertisement');
                      dns DNS server and cache information');
                      routing Routing table');
                      igmp_proxy IGMP Proxy');
                      igmp_snooping IGMP Snooping Table');
                      wlan WLAN status and information');
                      module Software version information');
                      memory Memory and CPU utilization');
                      speed Speed dial');
                      webdav WebDAV URL');
                      bonding_client Bonding HA client');
                      bonding_tunnel Bonding tunnel');
                      filterlist Filter list table');
                      bonding_tr181 Bonding TR-181');
                      lteinfo LTE information');
                      Status System information (no login needed)');
                      SecureStatus Secure system information (login needed)');
                      Overview General status information, i.e. tunnel status');
                      modules ');
                      Abuse trusted SMTP servers configuration');
                      DECTStation DECT configuration');
                      hsdelmobil DECT handset status');
                      LAN LAN status (DHCP assigned IPs ect.)');
                      ! zusätzliche Endpoints lt https://github.com/Stricted/speedport-hybrid-php-api
                      ! Connect
                      WLANBasic
                      WLANAccess
                      NASLight
                      INetIP
                      FilterAndTime
                      Portforwarding
                      PhoneBook
                      PhoneCalls
                      SystemMessages
                      DynDNS
                      ! */
                      // ############################################################################
                      // # Variablen #
                      // ############################################################################
                      ! var selection_dsl = false;
                      var selection_interfaces = false;
                      var selection_arp = false;
                      var selection_session = false;
                      var selection_dhcp_client = false;
                      var selection_dhcp_server = false;
                      var selection_ipv6 = false;
                      var selection_dns = false;
                      var selection_routing = false;
                      var selection_igmp_proxy = false;
                      var selection_igmp_snooping = false;
                      var selection_wlan = false;
                      var selection_module = false;
                      var selection_memory = false;
                      var selection_speed = false;
                      var selection_webdav = false;
                      var selection_bonding_client = false;
                      var selection_bonding_tunnel = false;
                      var selection_filterlist = false;
                      var selection_bonding_tr181 = false;
                      var selection_lteinfo = true;
                      var selection_Status = false;
                      var selection_SecureStatus = false;
                      var selection_Overview = false;
                      var selection_modules = false;
                      var selection_Abuse = false;
                      var selection_DECTStation = false;
                      var selection_hsdelmobil = false;
                      var selection_LAN = false;
                      //
                      // var selection_PhoneCalls = true;
                      //
                      var dpWrite_section = "";
                      var actual_section = "";
                      ! // ################################################################
                      // # Datenpunkte erstellen #
                      // ################################################################
                      if (selection_lteinfo === true) {
                      // {"imei":"864230023577834","imsi":"262014944528183","device_status":"Attached","card_status":"SIM OK","antenna_mode":"Antennal set to external","phycellid":"72","cellid":"28385538","rsrp":"-85","rsrq":"-10","service_status":"Effective service","tac":"13500"}
                      ! // createState(instanz + pfad + 'LTE-Info.' + 'dsl_status',,{name: 'DSL Status', desc: 'DSL-Satus: online-offline', type: 'boolean'});
                      createState(instanz + pfad + 'LTE-Info.' + 'rsrpQual',{name: 'RSRP-Qualitaet', desc: 'Qualität des RSRP-Wertes', type: 'number'});
                      createState(instanz + pfad + 'LTE-Info.' + 'rsrqQual',{name: 'RSRQ-Qualitaet', desc: 'Qualität des RSRQ-Wertes', type: 'number'});
                      createState(instanz + pfad + 'LTE-Info.' + 'IMEI',{name: 'IMEI', desc: 'IMEI der Sim-Karte', type: 'string'});
                      createState(instanz + pfad + 'LTE-Info.' + 'IMSI',{name: 'IMSI', desc: 'IMSI der Sim-Karte', type: 'string'});
                      createState(instanz + pfad + 'LTE-Info.' + 'Device-Status',{name: 'Device-Status', desc: 'Device-Status', type: 'string'});
                      createState(instanz + pfad + 'LTE-Info.' + 'Card-Status',{name: 'Card-Status', desc: 'Status der Sim-Karte', type: 'string'});
                      createState(instanz + pfad + 'LTE-Info.' + 'Antenna-Mode',{name: 'Antenna-Mode', desc: 'Antennen-Mode', type: 'string'});
                      createState(instanz + pfad + 'LTE-Info.' + 'phycellid',{name: 'phycellid', desc: 'phycellid', type: 'string'});
                      createState(instanz + pfad + 'LTE-Info.' + 'cellid',{name: 'cellid', desc: 'cellid', type: 'string'});
                      createState(instanz + pfad + 'LTE-Info.' + 'rsrp',{name: 'rsrp', desc: 'rsrp', type: 'string'});
                      createState(instanz + pfad + 'LTE-Info.' + 'rsrq',{name: 'rsrq', desc: 'rsrq', type: 'string'});
                      createState(instanz + pfad + 'LTE-Info.' + 'Service-Status',{name: 'Service-Status', desc: 'Service-Status', type: 'string'});
                      createState(instanz + pfad + 'LTE-Info.' + 'TAC',{name: 'TAC', desc: 'TAC', type: 'string'});
                      }

                      if (selection_dsl === true) {
                          
                        createState(instanz + pfad + 'DSL.Connection.' + 'dsl_operaing_mode',{name: 'Operating-Mode', desc: 'Art des DSL-Anschlusses', type: 'string'});
                        createState(instanz + pfad + 'DSL.Connection.' + 'path_mode',{name: 'Path-Mode', desc: 'Path-Mode', type: 'string'});
                        createState(instanz + pfad + 'DSL.Connection.' + 'state',{name: 'State', desc: 'Status', type: 'string'});
                        createState(instanz + pfad + 'DSL.Connection.' + 'training_results',{name: 'Training-Results', desc: 'Training-Results', type: 'string'});
                        createState(instanz + pfad + 'DSL.Connection.' + 'mode_lo',{name: 'Mode_Lo', desc: 'Mode_Lo', type: 'string'});
                        createState(instanz + pfad + 'DSL.Connection.' + 'vpi_vci',{name: 'VPI-VCI', desc: 'VPI-VCI', type: 'string'});
                        //
                        createState(instanz + pfad + 'DSL.Line.' + 'uactual',{name: 'uactual', desc: 'Aktuelle Upload-Rate', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'dactual',{name: 'dactual', desc: 'Aktuelle Download-Rate', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'uattainable',{name: 'uattainable', desc: 'uattainable', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'dattainable',{name: 'dattainable', desc: 'dattainable', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'uSNR',{name: 'uSNR', desc: 'uSNR', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'dSNR',{name: 'dSNR', desc: 'dSNR', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'uSignal',{name: 'uSignal', desc: 'uSignal', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'dSignal',{name: 'dSignal', desc: 'dSignal', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'uLine',{name: 'uLine', desc: 'uLine', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'dLine',{name: 'dLine', desc: 'dLine', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'uFEC_size',{name: 'uFEC_size', desc: 'uFEC_size', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'dFEC_size',{name: 'dFEC_size', desc: 'dFEC_size', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'uCodeword',{name: 'uCodeword', desc: 'uCodeword', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'dCodeword',{name: 'dCodeword', desc: 'dCodeword', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'uInterleave',{name: 'uInterleave', desc: 'uInterleave', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'dInterleave',{name: 'dInterleave', desc: 'dInterleave', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'uCRC',{name: 'uCRC', desc: 'uCRC', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'dCRC',{name: 'dCRC', desc: 'dCRC', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'uHEC',{name: 'uHEC', desc: 'uHEC', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'dHEC',{name: 'dHEC', desc: 'dHEC', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'uFEC',{name: 'uFEC', desc: 'uFEC', type: 'string'});
                        createState(instanz + pfad + 'DSL.Line.' + 'dFEC',{name: 'dFEC', desc: 'dFEC', type: 'string'});
                        //
                      }
                      

                      ! // ######################################################################
                      // # Abholen der Daten vom SpeedPort #
                      // ######################################################################
                      function getData() {
                      if (selection_lteinfo === true) {
                      log('Daten für LTE-Info werden abgefragt: ');
                      dpWrite_section = 'lteinfo';
                      exec("node " + l33tport_pfad + " -o json -f lteinfo", function(err, stdout, stderr) {
                      if (err) {
                      log(stderr,'error');
                      return;
                      }
                      log('Rückgabewert: ' + stdout);
                      writeDP(stdout,dpWrite_section);
                      dpWrite_section='';
                      });
                      }
                      if (selection_dsl === true) {
                      log('Daten für DSL werden abgefragt: ');
                      dpWrite_section = 'dsl';
                      exec("node " + l33tport_pfad + " -o json -f dsl", function(err, stdout, stderr) {
                      if (err) {
                      log(stderr,'error');
                      return;
                      }
                      log('Rückgabewert: ' + stdout);
                      writeDP(stdout,dpWrite_section);
                      dpWrite_section='';
                      });
                      }
                      }
                      ! function writeDP (jsonString,selection) {
                      ! var objects = JSON.parse(jsonString);
                      var jsonStr = jsonString;
                      log (jsonStr);

                      !
                      if (selection === 'lteinfo') {
                      var imei = objects.imei;
                      var imsi = objects.imsi;
                      var device_status = objects.device_status;
                      var card_status = objects.card_status;
                      var antenna_mode = objects.antenna_mode;
                      var phycellid = objects.phycellid;
                      var cellid = objects.cellid;
                      var rsrp = objects.rsrp;
                      var rsrq = objects.rsrq;
                      var service_status = objects.service_status;
                      var tac = objects.tac;
                      var rsrp_qual = 0;
                      var rsrq_qual = 0;

                        // SetState für lteinfo mit SubPfad LTE-Info
                        // setState(instanz + pfad + 'LTE-Info.' + Wertezweig,variable);
                        setState(instanz + pfad + 'LTE-Info.' + 'IMEI', imei);
                        setState(instanz + pfad + 'LTE-Info.' + 'IMSI', imsi);
                        setState(instanz + pfad + 'LTE-Info.' + 'Device-Status', device_status);
                        setState(instanz + pfad + 'LTE-Info.' + 'Card-Status', card_status);
                        setState(instanz + pfad + 'LTE-Info.' + 'Antenna-Mode', antenna_mode);
                        log('phycellid ist vom Typ: ' + typeof phycellid);
                        setState(instanz + pfad + 'LTE-Info.' + 'phycellid', phycellid);
                        setState(instanz + pfad + 'LTE-Info.' + 'cellid', cellid);
                        setState(instanz + pfad + 'LTE-Info.' + 'rsrp', rsrp);
                        setState(instanz + pfad + 'LTE-Info.' + 'rsrq', rsrq);
                        setState(instanz + pfad + 'LTE-Info.' + 'Service-Status', service_status);
                        setState(instanz + pfad + 'LTE-Info.' + 'TAC', tac);
                      

                      ! log ('RSRQ-Wert = ' + rsrq);
                      rsrq = parseInt(rsrq);
                      if(rsrq >= -15) rsrq_qual = 1;
                      if(rsrq >= -11) rsrq_qual = 2;
                      if(rsrq >= -8) rsrq_qual = 3;
                      if(rsrq >= -5) rsrq_qual = 4;
                      if(rsrq >= -3) rsrq_qual = 5;
                      setState(instanz + pfad + 'LTE-Info.' + 'rsrqQual', rsrq_qual);
                      ! // analog mit rsrp rsrp_qual
                      log ('rsrp-Wert = ' + rsrp);
                      rsrp = parseInt(rsrp);
                      if(rsrp >= -124) rsrp_qual = 1;
                      if(rsrp >= -109) rsrp_qual = 2;
                      if(rsrp >= -95) rsrp_qual =3;
                      if(rsrp >= -80) rsrp_qual =4;
                      if(rsrp >= -65) rsrp_qual =5;
                      ! setState(instanz + pfad + 'LTE-Info.' + 'rsrpQual', rsrp_qual);
                      !
                      }

                      if (selection === 'dsl') {
                      var dsl_operaing_mode = objects.Connection.dsl_operaing_mode;
                      var path_mode = objects.Connection.path_mode;
                      var state = objects.Connection.state;
                      var training_results = objects.Connection.training_results;
                      var mode_lo = objects.Connection.mode_lo;
                      var vpi_vci = objects.Connection.vpi_vci;
                      //
                      var uactual = objects.Line.uactual;
                      var dactual = objects.Line.dactual;
                      var uattainable = objects.Line.uattainable;
                      var dattainable = objects.Line.dattainable;
                      var uSNR = objects.Line.uSNR;
                      var dSNR = objects.Line.dSNR;
                      var uSignal = objects.Line.uSignal;
                      var dSignal = objects.Line.dSignal;
                      var uLine = objects.Line.uLine;
                      var dLine = objects.Line.dLine;
                      var uFEC_size = objects.Line.uFEC_size;
                      var dFEC_size = objects.Line.dFEC_size;
                      var uCodeword = objects.Line.uCodeword;
                      var dCodeword = objects.Line.dCodeword;
                      var uInterleave = objects.Line.uInterleave;
                      var dInterleave = objects.Line.dInterleave;
                      var uCRC = objects.Line.uCRC;
                      var dCRC = objects.Line.dCRC;
                      var uHEC = objects.Line.uHEC;
                      var dHEC = objects.Line.dHEC;
                      var uFEC = objects.Line.uFEC;
                      var dFEC = objects.Line.dFEC;

                        // SetState für lteinfo mit SubPfad LTE-Info
                        // setState(instanz + pfad + 'LTE-Info.' + Wertezweig,variable);
                        setState(instanz + pfad + 'DSL.Connection.' + 'dsl_operaing_mode', dsl_operaing_mode);
                        setState(instanz + pfad + 'DSL.Connection.' + 'path_mode', path_mode);
                        setState(instanz + pfad + 'DSL.Connection.' + 'state', state);
                        setState(instanz + pfad + 'DSL.Connection.' + 'training_results', training_results);
                        setState(instanz + pfad + 'DSL.Connection.' + 'mode_lo', mode_lo);
                        setState(instanz + pfad + 'DSL.Connection.' + 'vpi_vci', vpi_vci);
                        //
                        setState(instanz + pfad + 'DSL.Line.' + 'uactual', uactual);
                        setState(instanz + pfad + 'DSL.Line.' + 'dactual', dactual);
                        setState(instanz + pfad + 'DSL.Line.' + 'uattainable',uattainable );
                        setState(instanz + pfad + 'DSL.Line.' + 'dattainable',dattainable );
                        setState(instanz + pfad + 'DSL.Line.' + 'uSNR', uSNR);
                        setState(instanz + pfad + 'DSL.Line.' + 'dSNR',dSNR );
                        setState(instanz + pfad + 'DSL.Line.' + 'uSignal',uSignal );
                        setState(instanz + pfad + 'DSL.Line.' + 'dSignal',dSignal );
                        setState(instanz + pfad + 'DSL.Line.' + 'uLine',uLine );
                        setState(instanz + pfad + 'DSL.Line.' + 'dLine',dLine );
                        setState(instanz + pfad + 'DSL.Line.' + 'uFEC_size', uFEC_size);
                        setState(instanz + pfad + 'DSL.Line.' + 'dFEC_size', dFEC_size);
                        setState(instanz + pfad + 'DSL.Line.' + 'uCodeword', uCodeword);
                        setState(instanz + pfad + 'DSL.Line.' + 'dCodeword', dCodeword);
                        setState(instanz + pfad + 'DSL.Line.' + 'uInterleave',uInterleave );
                        setState(instanz + pfad + 'DSL.Line.' + 'dInterleave',dInterleave );
                        setState(instanz + pfad + 'DSL.Line.' + 'uCRC',uCRC );
                        setState(instanz + pfad + 'DSL.Line.' + 'dCRC',dCRC );
                        setState(instanz + pfad + 'DSL.Line.' + 'uHEC',uHEC );
                        setState(instanz + pfad + 'DSL.Line.' + 'dHEC',dHEC );
                        setState(instanz + pfad + 'DSL.Line.' + 'uFEC',uFEC );
                        setState(instanz + pfad + 'DSL.Line.' + 'dFEC',dFEC );
                      

                      }
                      }

                      ! // regelmässige Wiederholungen
                      // -----------------------------------------------------------------------------
                      schedule(cronStr, getData);
                      ! ````
                      ! Da ich ja im Ursprung das alles lieber als Adapter gehabt hätte, habe ich dies im Ansatz auf Github https://github.com/ssbingo/iobroker.speedport-hybrid mal versucht anzufangen.
                      ! Muss aber zugeben, dass ich da mangels Wissen komplett scheitere.
                      ! Vielleicht findet sich ja jemand, der Lust und Interesse hat, da mit zu werkeln.
                      ! Bis heute habe ich ersteinmal die Datenpunkte für die ersten 4 Rubriken definiert und die admin.html angepasst.
                      ! Die restlichen mit l33tport machbaren Rubriken werde ich nach und nach weiter einpflegen.
                      ! An dem eigentlichen Adapter sehe ich mich aber kläglich scheitern.
                      ! Gruss
                      ! Silvio
                      ! edit: Vorschalg von paul53 in script übernommen `

                      1 Reply Last reply Reply Quote 0
                      • S
                        sveni_lee last edited by

                        ich habe jetzt mal versucht den Adapter zu installieren…

                        allerdings bekomme ich schon einige Fehlermeldungen wenn ich versuche sjcl und commander zu installieren

                        ! ````
                        svenilee@Gotham-City:/opt/iobroker$ npm install sjcl
                        ! > bufferutil@1.1.0 install /opt/iobroker/node_modules/bufferutil
                        node-gyp rebuild
                        ! make: Verzeichnis „/opt/iobroker/node_modules/bufferutil/build“ wird betreten
                        CXX(target) Release/obj.target/bufferutil/src/bufferutil.o
                        In file included from ../node_modules/nan/nan.h:82:0,
                        from ../src/bufferutil.cc:16:
                        ../node_modules/nan/nan_new.h: In function ‘v8::Local NanIntern::To(v8::Handlev8::integer) [with T = v8::Int32; v8::Handle v8::integer= v8::Localv8::integer]’:
                        ../node_modules/nan/nan_new.h:34:64: warning: ‘v8::Local v8::int32v8::Value::ToInt32() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                        Tov8::int32(v8::Handle v8::integeri) { return i->ToInt32(); }
                        ^
                        In file included from ../src/bufferutil.cc:7:0:
                        /home/svenilee/.node-gyp/6.12.3/include/node/v8.h:8214:14: note: declared here
                        Local <int32>Value::ToInt32() const {
                        ^
                        In file included from ../node_modules/nan/nan.h:82:0,
                        from ../src/bufferutil.cc:16:
                        ../node_modules/nan/nan_new.h: In function ‘v8::Local NanIntern::To(v8::Handlev8::integer) [with T = v8::Uint32; v8::Handle v8::integer= v8::Localv8::integer]’:
                        ../node_modules/nan/nan_new.h:39:65: warning: ‘v8::Local v8::uint32v8::Value::ToUint32() const’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                        Tov8::uint32(v8::Handle v8::integeri) { return i->ToUint32(); }
                        ^
                        In file included from ../src/bufferutil.cc:7:0:
                        /home/svenilee/.node-gyp/6.12.3/include/node/v8.h:8208:15: note: declared here
                        Local <uint32>Value::ToUint32() const {
                        ^
                        In file included from ../node_modules/nan/nan_new.h:189:0,
                        from ../node_modules/nan/nan.h:82,
                        from ../src/bufferutil.cc:16:
                        ../node_modules/nan/nan_implementation_12_inl.h: In static member function ‘static NanIntern::FactoryBasev8::booleanobject::return_t NanIntern::Factoryv8::booleanobject::New(bool)’:
                        ../node_modules/nan/nan_implementation_12_inl.h:49:38: warning: ‘static v8::Local v8::valuev8::BooleanObject::New(bool)’ is deprecated: Pass an isolate [-Wdeprecated-declarations]
                        return v8::BooleanObject::New(value).Asv8::booleanobject();
                        ^
                        In file included from /home/svenilee/.node-gyp/6.12.3/include/node/v8.h:25:0,
                        from ../src/bufferutil.cc:7:
                        /home/svenilee/.node-gyp/6.12.3/include/node/v8.h:4009:56: note: declared here
                        V8_DEPRECATED("Pass an isolate", static Local <value>New(bool value));
                        ^
                        /home/svenilee/.node-gyp/6.12.3/include/node/v8config.h:333:3: note: in definition of macro ‘V8_DEPRECATED’
                        declarator attribute((deprecated(message)))
                        ^
                        In file included from ../node_modules/nan/nan_new.h:189:0,
                        from ../node_modules/nan/nan.h:82,
                        from ../src/bufferutil.cc:16:
                        ../node_modules/nan/nan_implementation_12_inl.h: In static member function ‘static NanIntern::FactoryBasev8::script::return_t NanIntern::Factoryv8::script::New(v8::Localv8::string)’:
                        ../node_modules/nan/nan_implementation_12_inl.h:166:69: warning: ‘static v8::Local v8::scriptv8::ScriptCompiler::Compile(v8::Isolate*, v8::ScriptCompiler::Source*, v8::ScriptCompiler::CompileOptions)’ is deprecated: Use maybe version [-Wdeprecated-declarations]
                        return v8::ScriptCompiler::Compile(v8::Isolate::GetCurrent(), &src);
                        ^
                        In file included from /home/svenilee/.node-gyp/6.12.3/include/node/v8.h:25:0,
                        from ../src/bufferutil.cc:7:
                        /home/svenilee/.node-gyp/6.12.3/include/node/v8.h:1354:21: note: declared here
                        Local</v8::script></v8::string></v8::script></v8::script></value></v8::booleanobject></v8::value></v8::booleanobject></v8::booleanobject></uint32></v8::integer></v8::uint32></v8::uint32></v8::integer></v8::integer></v8::integer></int32></v8::integer></v8::int32></v8::int32></v8::integer></v8::integer></v8::integer>

                        1 Reply Last reply Reply Quote 0
                        • First post
                          Last post

                        Support us

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

                        816
                        Online

                        31.9k
                        Users

                        80.1k
                        Topics

                        1.3m
                        Posts

                        10
                        18
                        5411
                        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