Energie-Visualisierung für zu Hause, Beschreibung siehe hier readme.md.
Für die Benutzung des Programms werden gewisse technische Kenntnisse, wie das erstellen einer Datenbank, sowie das kopieren der Programmdateien auf den Webserver vorrausgesetzt.
Die Installation erfolgt manuell, es gibt keinen automatischen Installationsmechanismus.
- Webserversystem mit LAMP-Stack
- PHP 8.3
- Mysql / Maria Datenbank
- Webserver
- Diese Projekdateien in einem Verzeichnis auf dem Rechner lokal herunterladen
- Datenbank beim Provider erstellen und Zugangsdaten für später notieren.
- Schema der Datenbank erstellen, mit einem Datenbanktool.
- Das DB-Skript ist hier zu finden: scripts\sql-scripts\create-table.sql
- Bei der Erfassung von Echtzeitdaten enstehen z.B. im 2 Sekundentakt ca. 1 Million Datensätze pro Monat
- Bitte regelmäßg Datensicherungen durchführen, auf jeden Fall BEVOR Updates installiert werden
- Eine eigene Config-Datei im Ordner config erstellen mit dem Namen: local-config.php
- Als Vorlage die Daten local-config.php.sample benutzen
- Die geforderten Daten eintragen
- Der hier eingetragene API-Key muss auch bei den Shelly-Skripten verwendet werden
- Hier können auch eigene Konfigurationen, z.B. zu den gezeigten Chart-Metriken konfiguriert werden.
- Die heruntergeladenen Dateien inkl. der eigenen Config-Datei per SFTP o.ä. auf den Webserver übertragen
Falls man keine Echtzeitdaten verwendet, kann man die Navigation so anpassen um die Ansichten hierfür zu entfernen.
Navigation
- Datei: views\partials\navigation.phtml
- Für die Variable $pages die Seite entfernen: Startseite, Stunden, sowie die Tagesansicht
Startseite
- Datei: index.php
- Hier z.B. die monthsOverview.php eintragen
Für die Erfassung von Echtzeidaten müssen auf jedem Energiemessgerät die Shelly-Skripte installiert werden
Generell sind alle Skripte für die Erfassung der Energiewerte identisch und unterscheiden sich nur durch die Konfiguration im oberen Abschnitt. Die Skripte erkennen automatisch ob sie auf einem Shelly-EM oder Shelly PM laufen.
Für die Verbrauchsmessung ist ein Skript vorgesehen, welches den aufsummierten Verbrauch aller 3 Phasen als Summe speichert.
Im oberen Abschnitt sind folgende Parameter anzupassen:
- loggingUrl
- API-Key (wie in der local-config.php angegeben)
Das Skript ist hier zu finden scripts\shelly-scripts\Shelly-Pro3EM-SendToLogger.js
Es ist möglich die Stromerzeugung für jede Phase einzeln zu messen. Hierfür ist für jeden Energiemesser ein Skript anzulegen.
Im oberen Abschnitt sind folgende Parameter anzupassen:
- loggingUrl
- API-Key (wie in der local-config.php angegeben)
- devicePhase
Das Skript ist hier zu finden scripts\shelly-scripts\Shelly-Plus1PM-SendToLogger.js
Um die Echtzeitdaten für den schnelleren Zugriff aufzusummieren wird ein eigenes Skript benötigt. Dies kann man entweder vom Shelly oder über einen eigenen Cronjob starten. Bei mir läuft es alle 60 Sekunden auf einem Shelly, z.B. dem EM.
Das Skript ist hier zu finden scripts\shelly-scripts\Shelly-Pro3EM-Trigger_UnifyData.js
Bei mir kam es vor, das die Shelly-Skripte ab und zu stehen geblieben sind. Für diesen Fall kann auf jedem Energiemessgerät zusätzlich ein Autorestart-Skript angelegt werden.
Im oberen Abschnitt sind folgende Parameter anzupassen:
- targetScriptId
Das Skript ist hier zu finden scripts\shelly-scripts\Shelly-AutoRestart.js
Um einen Passwortschutz einzurichten, ist es wichtig, das api
-Verzeichnis nicht zu schützen, da die API-Aufrufe sonst nicht funktionieren. Für den API-Schutz ist der API-Key vorgesehen.
Im api
-Ordner liegt bereits eine .htaccess
-Datei, die den Schutz aufhebt mit der Anweisung:
Require all granted
Um einen Schutz einzurichten, muss im Hauptverzeichnis des Projekts eine Standard .htaccess- und .htpasswd-Datei abgelegt werden.
Vorgehen:
- Verwenden Sie einen Online-Generator für .htpasswd, indem Sie nach 'htpasswd Generator' suchen.
- Hinweis: Der vollständige Pfad zur .htpasswd-Datei muss in der .htaccess-Datei hinterlegt werden. Andernfalls kann ein Internal Server Error auftreten.
Beispiel .htaccess-Datei:
AuthName "Bitte Anmelden"
AuthUserFile /www/htdocs/[pfad]/[zum]/[projekt]/.htpasswd
Require valid-user