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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Entwicklung
  4. Mehrere requests syncron laufen lassen

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.7k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.1k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.0k

Mehrere requests syncron laufen lassen

Geplant Angeheftet Gesperrt Verschoben Entwicklung
3 Beiträge 2 Kommentatoren 326 Aufrufe
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • MeistertrM Offline
    MeistertrM Offline
    Meistertr
    Developer
    schrieb am zuletzt editiert von
    #1

    Hallo Leute, ich sitze gerade an einem neuen Adapter wo ich 6 http requests abwarten muss bis ich alle Daten habe um weiter zu machen. wie kann ich das am besten umsetzen mit cb finde ich ein bisschen unelegant da dann am ende da die dann ja alle ineinander verschachtelt sind. mit timeout ist auch nicht so schön, gibt es hier was elegantes wo ich nicht drauf komme? mfg Tobi

     mqttcloud.userdata = function (cb) {
            _get('GET', 'users/me', function (data) {
                console.log(JSON.stringify(data))
                ownData = data;
                if (typeof cb === "function") cb(data);
    
                return data
            });
        }
        mqttcloud.userdevices = function (cb) {
            _get('GET', 'product-items', function (data) {
                ownDevices = data;
                console.log(JSON.stringify(data))
                if (typeof cb === "function") cb(data);
            });
        }
        mqttcloud.usercert = function (cb) {
            _get('GET', 'users/certificate', function (data) {
                ownCert = data;
                console.log(JSON.stringify(data))
                if (typeof cb === "function") cb(data);
            });
        }
        mqttcloud.devices = function (cb) {
            _get('GET', 'products', function (data) {
                deviceList = data;
                console.log(JSON.stringify(data))
                if (typeof cb === "function") cb(data);
            });
        }
        mqttcloud.boards = function (cb) {
            _get('GET', 'boards', function (data) {
                boardList = data;
                console.log(JSON.stringify(data))
                if (typeof cb === "function") cb(data);
            });
        }
        function _get(method, path, cb) {
    
            if (ACCESS_TOKEN === '' || ACCESS_TYPE === '') {
                _getticket(function () {
                    _get(method, path, cb)
                });
                return;
            }
            var headers = {
                "Content-Type": "application/json",
                "Authorization": ACCESS_TYPE + " " + ACCESS_TOKEN,
            };
    
            var options = {
                host: URL,
                path: PATH + path,
                port: 443,
                method: method,
                headers: headers
            };
    
            var req = https.request(options, function (res) {
                var body = "";
    
                res.setEncoding('utf8');
                res.on('data', function (d) { body += d });
                res.on('end', function () { cb(JSON.parse(body)) });
            });
            req.on('error', function (e) { this.adapter.log.error("api errror " + e) });
            req.end();
        };
    

    hier mal die request funktionen

    1 Antwort Letzte Antwort
    0
    • apollon77A Offline
      apollon77A Offline
      apollon77
      schrieb am zuletzt editiert von
      #2

      Callbacks mit einem Zähler geht, die bei jedem Response erniedrigt wird. Ansonsten wäre die Antwort von AlCalzone garantiert Promises :-)

      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 Antwort Letzte Antwort
      0
      • MeistertrM Offline
        MeistertrM Offline
        Meistertr
        Developer
        schrieb am zuletzt editiert von
        #3

        da ich mit der zeit gehen will und mich promises interessiert, versuche ich das mal…

        1 Antwort Letzte Antwort
        0
        Antworten
        • In einem neuen Thema antworten
        Anmelden zum Antworten
        • Älteste zuerst
        • Neuste zuerst
        • Meiste Stimmen


        Support us

        ioBroker
        Community Adapters
        Donate

        873

        Online

        32.4k

        Benutzer

        81.5k

        Themen

        1.3m

        Beiträge
        Community
        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
        ioBroker Community 2014-2025
        logo
        • Anmelden

        • Du hast noch kein Konto? Registrieren

        • Anmelden oder registrieren, um zu suchen
        • Erster Beitrag
          Letzter Beitrag
        0
        • Home
        • Aktuell
        • Tags
        • Ungelesen 0
        • Kategorien
        • Unreplied
        • Beliebt
        • GitHub
        • Docu
        • Hilfe