NEWS
[Linux Shell-Skript] WLAN-Wetterstation
-
@negalein Das wird nur noch bei dir so sein, der ist seit 21.01.2021 schon "number"
createState(DP+"Info.Station_Batteriestatus" , 0, {name: "Batteriestatus [0=OK, 1=Alarm]", type: "number", role: "value" });
(Gleiches Thema wie beim "Name" die "Bezeichnung 0 und 1...")
Stell ihn einfach von Zeichenkette auf Zahl um und Ruhe ist -
Hallo zusammen,
danke, habe nun den Sainlogic Adapter gestoppt und alles ist gut
Nochmals besten Dank
-
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Stell ihn einfach von Zeichenkette auf Zahl um und Ruhe ist
Jetzt zitiere ich mich schon selbst...
...aber ohne etwas lancieren/forcieren zu wollen, mit der Rest API kann man auch bestehende Objekte ändern. Falls (s)ich also mal im Nachgang der Typ etc. eines Objektes ändern müsste, könnte der ws_updater dies zukünftig erledigen und jeder hat den korrekten Objekt-Stand. Allerdings nur Nutzer der Rest API
Bis die hier im Projekt aber Standard wird, wird noch so einige Zeit vergehen. Die Simple-API läuft dafür einfach zu gut.
-
Da keine offensichtlichen Fehler aufgetreten sind:
Neues Release des Wetterstation WLAN-Skriptes auf GitHub V2.15.0
- + neuer DP "Meldungen"; für Status- und Fehlermeldungen
- + Datenübertragung an Wunderground.com auch bei eigenem DNS-Server (Protokoll #9)(@git-ZeR0)
- + Windrichtung und -geschwindigkeit der letzten 10 Minuten (aktuell HP1000SE Pro)
- + ws_updater: anlegen neuer Datenpunkte per Rest-API möglich
Wie immer zu finden im GitHub
Update-Routine von Vorgängerversion:
- aktuellen WS-Updater nutzen (Download falls älter als V2.12.1:
wget -O ws_updater.sh https://raw.githubusercontent.com/SBorg2014/WLAN-Wetterstation/master/ws_updater.sh
) - wetterstation.js muss ebenfalls im JavaScript-Adapter ersetzt und einmalig ausgeführt werden (neue Datenpunkte)
./ws_updater.sh
im Installationsverzeichnis ausführen- Menüpunkt "4" wählen und die Fragen beantworten
Update kann durchgeführt werden wenn man die neuen Funktionen nutzen möchte oder einfach aktuell sein möchte
Mit diesem Update unterstützt der ws_updater zukünftig die Rest-API. Somit können Nutzer der Rest-API in Zukunft auf die Änderungen mittels der wetterstation.js verzichten. Dies erledigt dann die Rest-API.
Der Einsatz der Rest-API ist nicht zwingend erforderlich sondern rein optional möglich! Bei installierter Rest-API (dies prüft der ws_updater) werden die ggf. neuen Datenpunkte automatisch angelegt, ansonsten muss man halt weiter wie gehabt die wetterstation.js-Routine nutzen. -
@sborg
Ich habe ein Multihast-System. Auf einem Slave läuft die Simple.API. Ich habe nun auf dem Master die Rest.API installiert. Der Update V2.15 erkennt diese nicht. Kann es sein, dass die Rest.API auf dem gleichen Host wie die Simple.API installiert werden muss? Dann hätte ich die die Bitte, dass der Server für die Rest.API konfiguriert werden könnte (Eingabe IP).Danke für das tolle Projekt, die Wetterstation läuft Tiptop!
-
@sborg
Hier noch eine Rückmeldung:
die Datenpunkte Wind_10min und Windrichtung_10min aktualisieren sich nicht. Muss in der *.conf ein Eintrag gesetzt werden? -
@sborg said in [Linux Shell-Skript] WLAN-Wetterstation:
Mit diesem Update unterstützt der ws_updater zukünftig die Rest-API.
Sehe ich das richtig, dass die Simple und die Restful parallel laufen oder muss man in die Config die Restful-IP statt der Simple-IP eintragen?
-
@martybr sagte in [Linux Shell-Skript] WLAN-Wetterstation:
@sborg
Ich habe ein Multihast-System. Auf einem Slave läuft die Simple.API. Ich habe nun auf dem Master die Rest.API installiert. Der Update V2.15 erkennt diese nicht. Kann es sein, dass die Rest.API auf dem gleichen Host wie die Simple.API installiert werden muss? Dann hätte ich die die Bitte, dass der Server für die Rest.API konfiguriert werden könnte (Eingabe IP).Danke für das tolle Projekt, die Wetterstation läuft Tiptop!
Nein, wo ist egal. Allerdings beißt sich da der Hund selbst in den Schwanz (einmalig). Zur 1. Laufzeit prüft er auf die Rest-API, hat aber in der *.conf noch keine Zugangsdaten. Wenn du die also jetzt einträgst "lüppt dat och"
Hast du eine HP1000SE Pro ?
+Windrichtung und -geschwindigkeit der letzten 10 Minuten (aktuell HP1000SE Pro)
Nur die unterstützt das derzeit. Mit der kommenden V2.16.0 (bald als Beta) berechne ich die Windrichtung für alle Stationen. Geschwindigkeit muss ich dann noch umsetzen.
-
@boronsbruder sagte in [Linux Shell-Skript] WLAN-Wetterstation:
@sborg said in [Linux Shell-Skript] WLAN-Wetterstation:
Mit diesem Update unterstützt der ws_updater zukünftig die Rest-API.
Sehe ich das richtig, dass die Simple und die Restful parallel laufen oder muss man in die Config die Restful-IP statt der Simple-IP eintragen?
Jepp, die laufen parallel. Die Simple-API ist auch noch ein muss, die Rest-API eine Zusatzoption (derzeit für das erstellen von neuen Datenpunkten). Müssen auch beide bei Bedarf in der conf eingetragen sein. Nicht als "Test-Spielerei", sondern als echte Option, da ich anders keine neuen Objekte im ioB anlegen kann. Weder "iob/iobroker" im Terminal, noch die Simple-API bieten das an.
-
@sborg said in [Linux Shell-Skript] WLAN-Wetterstation:
Müssen auch beide bei Bedarf in der conf eingetragen sein.
Wo müssen die Daten der Restful rein?
Hab nur
#ioBroker-IP und Port der Simple-Restful-API [xxx.xxx.xxx.xxx:xxxxx] IPP=xxx.xxx.xxx.xxx:8087
in meiner config
Edith:
Zur 1. Laufzeit prüft er auf die Rest-API, hat aber in der *.conf noch keine Zugangsdaten.
Aha, muss ich wohl noch warten...
-
@boronsbruder Arrgh, ne, mist wenn man doof ist oder auch nur zu viel gleichzeitig macht...
Die Konfiguration wird erst mit der 16er eingeführt, die 15er enthält nur die Vorbereitungen dafür. Deswegen muss bei der 15er auch noch mittels der wetterstation.js hantiert werden.
Ich mache aber gerade die 16er als Beta fertig (durchschnittliche Windrichtung der letzten 10 Minuten für alle Stationen)
-
@boronsbruder Hast du ebenfalls ein Multihost-System? Das kann ich leider nicht testen und der Test auf die Rest-API müsste auch schon jetzt funktionieren, da der ohne Zugangsdaten nur mittels "iob" ausgeführt wird.
Was liefert denn ein
iob status rest-api.0
? Genau die Ausgabe wird auf is running geprüft. -
@sborg sorry, echt keine zeit gefunden fürs rumtesten. gerade das update gemacht.
was soll mir das jetzt sagen?┌────────────────────────┐ │ │ │ WS-Updater V2.15.0 │ │ │ └────────────────────────┘ Soll die wetterstation.conf nun auf eine neue Version gepatcht werden? [J/N]: j Lege Sicherungskopie der wetterstation.conf an... Patche wetterstation.conf auf V2.15.0 ... Fertig... Die Datenübertragung an Wunderground.com kann nun aktiviert werden! Update ausgeführt. Soll der Service nun neu gestartet werden? [J/N]: woody@ioBroker:~$
datenübertragung starten?
-
@da_woody Macht doch nix, nur je mehr testen desto eher fallen (hoffentlich keine) Fehler auf.
datenübertragung starten?
Nö, außer du willst deine Daten an Wunderground übertragen und arbeitest mit eigenem DNS-Server, weil deine Station sich nicht per WS View[+] App auf einen eigenen "Wetterserver" konfigurieren lässt:
- Datenübertragung an Wunderground.com auch bei eigenem DNS-Server (Protokoll #9)(@git-ZeR0)
-
Entweder bin ich zu doof dafür aber beim ausführen von ./ws_updater.sh bekomm ich nen fehler:
┌────────────────────────┐ │ │ │ WS-Updater V2.15.0 │ │ │ └────────────────────────┘ Ausführung als "root" nicht möglich...!
Mach ich was falsch?
-
@mugel80 sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Mach ich was falsch?
Offenbar werkelst du da als root herum.
Warum auch immer. Das ist schonmal grundsätzlich falsch.Also als user anmelden und das skript mit den richtigen Rechten (als Standard-User!) ausführen.
-
@sborg Bin wieder da.
Hier die Ausgabe:
martin@iobroker:~$ iob status rest-api.0 Instance "rest-api.0" is running martin@iobroker:~$
-
@sborg Ich habe die DP1500 Wi-Fi Wetterserver USB-Dongle & WH3000SE All-in-One Außensensor mit dem DP100 Bodenfeuchtesensor.
-
@thomas-braun sagte in [Linux Shell-Skript] WLAN-Wetterstation:
@mugel80 sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Mach ich was falsch?
Offenbar werkelst du da als root herum.
Warum auch immer. Das ist schonmal grundsätzlich falsch.Also als user anmelden und das skript mit den richtigen Rechten (als Standard-User!) ausführen.
Hab den Fehler gefunden.
Danke für die Hilfe. -
@martybr So ganz mag es mir noch nicht einleuchten. Aber an der Hardware liegt es nicht.
Ich habe zwar mal wieder ein Gleichheitszeichen vergessen, müsste aber bei "Debian" als Distri egal sein (zumindest läuft es bei mir und @Negalein hatte mit seiner Diät-Himbeere [ ] auch keine Probleme).Immerhin liefert auch der Multihost die selbe Ausgabe. Versuche bitte mal die aktuelle (eigentlich falsche) Version (2 Befehle nacheinander):
test=$(iob status rest-api.0|cut -d'"' -f3) if [ "${test}" = " is running" ]; then echo API läuft; fi
dann die korrekte:
test=$(iob status rest-api.0|cut -d'"' -f3) if [ "${test}" == " is running" ]; then echo API läuft; fi
zu guter Letzt die neue und eleganteste mittels RegEx:
if [[ $(iob status rest-api.0) =~ "is running" ]]; then echo API läuft; fi