Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • 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. Hardware
  4. [gelöst] Sensibo per Javascript abfragen und ansteuern

NEWS

  • Neuer ioBroker-Blog online: Monatsrückblick März/April 2026
    BluefoxB
    Bluefox
    6
    1
    252

  • Verwendung von KI bitte immer deutlich kennzeichnen
    HomoranH
    Homoran
    9
    1
    243

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    900

[gelöst] Sensibo per Javascript abfragen und ansteuern

Geplant Angeheftet Gesperrt Verschoben Hardware
1 Beiträge 1 Kommentatoren 209 Aufrufe 1 Beobachtet
  • Ä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.
  • D Offline
    D Offline
    drloksoft
    schrieb am zuletzt editiert von
    #1

    Hallo,
    ich habe ein kleines Luftfeuchtigkeitsproblem in einem Raum, in dem eine alte - nicht smarte - Klimaanlage steht. Diese kann ich mit einem Sensibo Adapter ansteuern, den ich wiederum per API über's Internet ansteuern kann.

    Ich habe mir ein Javaskript erstellt, welches alles 20 minuten die Luftfeuchtigkeit überprüft und die Klimaanlage anschaltet, wenn die Feuchtigkeit im Raum höher als 75% ist. Ebenso wied die Klimaanlage ausgeschaltet, wenn die Feuchtigkeit unter 75% ist.

    Device ID und API Key könnt Ihr mit Eurem Sensibo Account hier einsehen/erstellen:
    https://new-home.sensibo.com/#/pods

    Für den Fall, dass jemand so etwas sucht, bzw. gebrauchen kann, poste ich mal den Code.
    Stelle vorher sicher, dass node-fetch installiert ist. Auf der Shell Console: "npm install node-fetch"

    const fetch = require(`node-fetch`);
    
    const apiKey = `XXX`;    // Bitte deinen API-Schlüssel hier einfügen
    const deviceId = `XXX`;                        // Bitte deine Device-ID hier einfügen
    const urlBase = `https://home.sensibo.com/api/v2/pods/${deviceId}`;
    //const fetch = require('node-fetch');
    
    // Funktion zum Abrufen des Gerätestatus
    async function getHumidity() {
        const url = `${urlBase}/measurements?apiKey=${apiKey}`;
        console.log(`Abrufen der Luftfeuchtigkeit von URL: ${url}`);
        
        try {
            const response = await fetch(url);
            if (!response.ok) {
                const errorDetails = await response.text();
                throw new Error(`Netzwerkantwort war nicht ok: ${response.status} ${response.statusText} - ${errorDetails}`);
            }
            const data = await response.json();
            console.log('Erhaltene Daten:', JSON.stringify(data, null, 2));
    
            // Überprüfen Sie, ob die Datenstruktur korrekt ist
            if (!data.result || !data.result[0] || typeof data.result[0].humidity !== 'number') {
                throw new Error('Unerwartete Datenstruktur: ' + JSON.stringify(data));
            }
    
            return data.result[0].humidity;
        } catch (error) {
            console.error('Fehler beim Abrufen der Luftfeuchtigkeit:', error);
            throw error; // Weiterhin den Fehler werfen, damit er behandelt werden kann
        }
    }
    
    // Funktion zum Ein- und Ausschalten der Klimaanlage
    async function setACState(on) {
        const url = `${urlBase}/acStates?apiKey=${apiKey}`;
        const payload = {
            acState: {
                on: on
            }
        };
        console.log(`Senden der AC-Zustandsänderung an URL: ${url} mit Payload:`, JSON.stringify(payload));
        try {
            const response = await fetch(url, {
                method: 'POST',
                headers: {
                    'Content-Type': 'application/json'
                },
                body: JSON.stringify(payload)
            });
    
            if (!response.ok) {
                const errorDetails = await response.text();
                throw new Error(`Netzwerkantwort war nicht ok: ${response.status} ${response.statusText} - ${errorDetails}`);
            }
    
            const data = await response.json();
            console.log('Antwort vom Setzen des Zustands:', JSON.stringify(data, null, 2));
            return data;
        } catch (error) {
            console.error('Fehler beim Setzen des AC-Zustands:', error);
            throw error; // Weiterhin den Fehler werfen, damit er behandelt werden kann
        }
    }
    
    // Hauptfunktion
    async function checkAndSetACState() {
        try {
            const humidity = await getHumidity();
            console.log(`Aktuelle Luftfeuchtigkeit: ${humidity}%`);
    
            if (humidity > 75) {
                console.log('Luftfeuchtigkeit ist über 75%. Klimaanlage wird eingeschaltet.');
                await setACState(true);
            } else {
                console.log('Luftfeuchtigkeit ist 75% oder weniger. Klimaanlage wird ausgeschaltet.');
                await setACState(false);
            }
        } catch (error) {
            console.error('Fehler in der Hauptfunktion:', error);
        }
    }
    
    // Intervall-Timer einstellen (20 Minuten)
    setInterval(checkAndSetACState, 20 * 60 * 1000);
    
    // Initialer Aufruf der Funktion
    checkAndSetACState();
    
    
    1 Antwort Letzte Antwort
    0

    Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

    Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

    Mit deinem Input könnte dieser Beitrag noch besser werden 💗

    Registrieren Anmelden
    Antworten
    • In einem neuen Thema antworten
    Anmelden zum Antworten
    • Älteste zuerst
    • Neuste zuerst
    • Meiste Stimmen


    Support us

    ioBroker
    Community Adapters
    Donate

    273

    Online

    32.8k

    Benutzer

    82.8k

    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