NEWS
Cyberpower Webseite der USV auslesen
-
Hallo zusammen,
leider stellt Cyberpower Business Lokal nicht alle Daten per SNMP bereit, die ich über die Cyberpower Business-Weboberfläche für meien Cyberpower-USV auslesen kann. Betroffen sind z.B. die Spannung in V.
Unter https://community.home-assistant.io/t/monitor-cyberpower-ups-plugged-into-windows-machine-via-usb/170497/3 habe ich eine Lösung gefunden, wie jemand das über Phyton realisiert hat:
import requests import paho.mqtt.client as paho import json url = "http://192.168.x.x:3052/local/rest/v1/login/verify" url2 = "http://192.168.x.x:3052/local/rest/v1/ups/status" payload = {"userName": "adminuser", "password": "adminpassword"} headers = {'Content-Type': "application/json"} response = requests.request("POST", url, json=payload, headers=headers) # the json parameter should handle encoding for you cookies = response.cookies response = requests.request("GET", url2, cookies=cookies) r_dictionary= response.json() iv = r_dictionary['input']['voltages'][0] ov = r_dictionary['output']['voltages'][0] ol = r_dictionary['output']['loads'][0] br = r_dictionary['battery']['remainingRunTimeInSecs']/60 brf = r_dictionary['battery']['remainingRunTimeFormated'] sys = r_dictionary['system']['stateText'] batt = r_dictionary['battery']['stateText'] cap = r_dictionary['battery']['capacity'] comm = r_dictionary['communicationAvaiable'] broker="192.168.x.x" port=1883 client1= paho.Client("control1") #create client object client1.connect(broker,port) #establish connection ret= client1.publish("ups1/iv",iv) ret= client1.publish("ups1/ov",ov) ret= client1.publish("ups1/ol",ol) ret= client1.publish("ups1/br",br) ret= client1.publish("ups1/sys",sys) ret= client1.publish("ups1/comm",comm) ret= client1.publish("ups1/brf",brf) ret= client1.publish("ups1/cap",cap) ret= client1.publish("ups1/batt",batt)
Ließe sich das für den ioBroker umschreiben?
Ich stelle mir ein JS-Skript oder Blockly mit JS-Skript vor, das z.B. alle 30 Sekunden die Daten der Webseite abfragt und in Datenpunkte schreibt.
-
@iobaer Python ist auch nicht schlechter als Javascript. Gibt es einen Grund gegen Python? Das Skript scheint ja zu funktionieren und die Daten landen so per MQTT auch im ioB.
Den Aufruf würde ich dann per simplen cron-Trigger realisieren:*/30 * * * * * /_pfad_/_skriptname_ >/dev/null 2>&1
-
@iobaer ja man kann es umschreiben.. ist ja nur ein aufruf einer url mit dazugehörigen cookie..axios ist dein freund in diesem fall
-
@sborg Ich nutze ja kein HASS und auch kein Phyton, von daher würde ich eigentlich ungern ein zweites System aufsetzen und betreiben, nur um an diese Werte zu gelangen.
@arteck Danke Dir, ich habe mich etwas eingelesen, finde aber nur sehr wenige Informationen dazu und fast keine Beispiele, vor allem keine für die Verwendung als einfaches Javascript. Es wäre lieb, wenn Du mir etwas unter die Arme greifen könntest. Alternativ müsste ich versuchen, die Webseite z.B. über AutoIT anzuzapfen und von dort aus, z.B. über die Web-API, in ioBroker zu "schieben". Frag mich eh, warum man SNMP anbietet, dann aber viele Werte überhaupt nicht auslesbar macht (ggf. soll man die Management-Card kaufen).
-
@iobaer Linux oder Windows? Bei Linux wäre Python schon installiert, bei Windows muss man es ggf. nachinstallieren.
Das Skript läuft so schon ohne Änderung, dass hat zuerst mal nix mit ioB etc. zu tun. Es ist ein einfaches Skript welches eine Web-Site parst und die Daten dann per MQTT publisht (und das kann dann der ioB mittels MQTT-Adapter).Außer den URLs und deinen Zugangsdaten brauchst du am Skript nichts ändern, außer du möchtest den Pfad/Bezeichnung der MQTT-Nachrichten noch ändern.
Einzig wirst du unter Python noch den paho-MQTT-Client nachinstallieren müssen.In JS ist das auch kein Hexenwerk. Persönlich bin ich halt einfach faul und muss das Rad nicht zum 2. mal erfinden
-
@sborg Danke Dir. Ich könnte also - ganz einfache Variante - über ein Blockly dieses Skript, das ich irgendwo abgelegt habe, aufrufen (Zugangsdaten natürlich eingeben), zumal mein ioBroker unter Debian 11 läuft?
-
@iobaer Eigentlich die einfachste Variante:
- du fügst an den Anfang des Skriptes
#!/usr/bin/python
an - dann machst du abc.py (nenne ich mal so) noch ausführbar
- jetzt nur noch einen cronjob anlegen:
sudo crontab -e
Wichtig: die cron-Tabelle muss immer mit einer Leerzeile enden! Also den folgenden Eintrag nicht einfach als letzte Zeile anhängen.
*/30 * * * * * /_pfad_wo_das_skript_liegt_/abc.py >/dev/null 2>&1
Wenn du im Pfad stehst sollte nun
./abc.py
funktionieren. Wahrscheinlich kommt wg. des fehlenden Paho-Clients noch ein Fehler, also den Client noch nachinstallieren:pip install paho-mqtt
Jetzt sollte es korrekt durchlaufen. Wenn du den MQTT-Adapter installiert hast, sollten nun in den Objekten des MQTT-Adapters deine Werte erscheinen ups1/iv usw. - du fügst an den Anfang des Skriptes
-
@sborg Ganz lieben Dank. Nach einigen Problemen klappt es nun, wobei ich das Skript jeweils über ein Blockly aufrufe.
Was ich aber nicht hinbekommen habe: wie kann ich Werte direkt an Blockly oder JavaScript in ioBroker zurückgeben, ohne den Umweg via MQTT? Hier kam wohl jemand damit auch nicht weiter: https://forum.iobroker.net/topic/28367/exec-rückgabewerte-aus-python-script-nutzen
-
@iobaer sagte in Cyberpower Webseite der USV auslesen:
wie kann ich Werte direkt an Blockly oder JavaScript in ioBroker zurückgeben, ohne den Umweg via MQTT?
wohl nicht mit diesem Skript.
dann musst du die Website eigenständig parsen.
-
@iobaer sagte: wie kann ich Werte direkt an Blockly oder JavaScript in ioBroker zurückgeben, ohne den Umweg via MQTT?
Schau Dir mal den Quellcode des NPM-Moduls cyberpower-powerpanel-status an. Das Modul holt sich ebenfalls die Daten über die REST-API.
-
@iobaer Dann kannst du den ganzen Part ab "broker" weglassen und brauchst nur die beiden letzten Zeilen hinzufügen (fehlende Werte hinzufügen und ggf. Bezeichnungen ändern
) :
#!/usr/bin/python import json iv="236" ov="233" ol="99" daten = json.dumps({'input': iv, 'output': ov, 'outload': ol}) print daten
(#1-#6 nur damit ich paar Pseudo-Daten habe)
Blocky dann sinngemäß und zeigt wo der Weg hingeht:
-
@paul53 sagte: Quellcode des NPM-Moduls cyberpower-powerpanel-status
Laut Quellcode des NPM-Moduls könnte das Skript etwa so aussehen:
const path = '0_userdata.0.usv.'; const url = 'http://192.168.x.x:3052/local/rest/v1/'; const cookieJar = request.jar(); const optionsLogin = { method: "POST", uri: url + 'login/verify', jar: cookieJar, json: { userName: "adminuser", password: "adminpassword" } }; const optionsStatus = { method: "GET", uri: url + 'ups/status', jar: cookieJar }; schedule('*/10 * * * * *', function() { request(optionsLogin, function(error, response, result) { if(error) log(error, 'warn'); else { optionsStatus.auth = {bearer: result}; request(optionsStatus, function(err, response, body) { if(err) log(err, 'warn'); else { log(body); const obj = JSON.parse(body); // wenn body JSON enthält // Auswertung z.B. setState(path + 'input.volt', parseFloat(obj.input.voltages[0]), true); } }); } }); });
-
Vielen lieben Dank Euch allen! Mit ein paar kleinen Anpassungen passt nun alles. Genial.
Ich bin froh, nun auch den Umweg über MQTT los zu sein, weil ich das auf der selben Maschine etwas überflüssig finde und es vor allem die Wartbarkeit weiter erschwert (bei Neuinstallationen). Dazu gab es Fehlermeldungen im ioBroker-Log, denen ich jetzt nicht nachgehen muss (wohl von paho).
Ich nutze übrigens das Skript ohne Benutzername und Passwort, das nur die Bearer-Authorization nutzt. Scheinbar läuft dieses Token nicht ab.
Edit: Ich habe jetzt das Pyton-Skript in Blockly so integriert, dass Blockly beim ioBroker-Start dieses auf Dateisystemebene anlegt und berechtigt, falls es noch nicht existiert. Wie oben erwähnt, denke ich da an Neuinstallationen etc.