Lichtsteuerung

Lampen, Blinkenlights und weitere Geräte, fernsteuerbar per Automatik, Website und Android-App.

Hardware


Kernstück des Ganzen sind SI2C-Instanzen an und. Daran hängen die Steuer-AVRs der jeweiligen Geräte und tun (wenn sie mit der richtigen Adresse angesprochen werden) Dinge.

Einige Verbraucher werden noch direkt über GPIO-Pins (Optokoppler + Transistor) geschaltet, das ist aber Legacy und wird abgebaut.

Die Schaltspannung der Schieberegister ist 12V und geht wahlweise direkt zum Kleinverbraucher oder zu einem 230V-Relais.

Software

 * dorfmap
 * dorfmap-deb (Helfer)

Automatik
Die Außenbeleuchtung wird automatisch nach der aktuellen Tageszeit geschaltet. Benutzt wird dazu die Perl-Library Astro::Sunrise, die anhand unserer Koordinaten und dem aktuellen Datum recht akkurate Zeiten für Sonnenauf- und -untergang berechnet. Per cronjob wird alle 6 Minuten überprüft, ob Nacht ist oder nicht, und entsprechend die Beleuchtung geschaltet.

Der HP2100 und die Windowgarden-Pumpe werden nach 20 Minuten automatisch abgeschaltet.

Manuell
Grundlage ist ein Grundriss des Clubraums. Aus einer Koordinatendatei wird ausgelesen, wo welche Lampe ist, und abhängig von ihrem Status ein entsprechendes Symbol angezeigt. Bei automatisch gesteuerten Lampen wird die Automatik gesteuert, alle anderen können durch einen Klick aufs Symbol getoggelt werden.

Weil die Karte eh schon da ist, wird außerdem der Status von einigen Servern / Embedded Hosts, unseren WLAN-APs und den Druckern angezeigt. Der ist sinnvollerweise auch read-only, die Hosts werden einfach angepingt. Eingeschaltete Hosts sind grün, ausgeschaltete grau oder rot.

Es gibt eine Reihe von Shortcuts, die mehrere Aktionen zusammenfassen. "Shutdown" schaltet z.B. alle Lampen aus und den Raumstatus auf nicht-öffentlich, "Putzen" sorgt für viel Licht, etc.

API
Es existiert eine API, unterstützt wird sowohl ein einfaches Textformat (z.B. für Shellskripte) als auch JSON. Für Textformat .txt an Anfragen anhängen (oder curl -H 'Accept: text/plain' benutzen), für JSON entsprechend .json bzw. application/json.

/get kann auch PNGs liefern, sie entsprechen den in der Übersicht sichtbaren.

Angeschlossene Geräte
Die genaue Zuordnung zwischen Kabel / GPIO-Pin und Gerät ist auf und  dokumentiert. Jede Automatik ist individuell deaktivierbar.

Die Automatik der Außenbeleuchtung lässt sich durch klick auf die Lampe an / aus schalten. Ausschalten passiert sofort, Einschalten dauert 1 bis 6 Minuten. Im Gegensatz zu anderen Aktionen ändert das auch nichts am Dorf-Shutdownstatus. Im Webinterface steht "A" für Automatik, "X" für keine Automatik.

Was weiterhin angezeigt wird:


 * Drucker (readonly, per ping, alle 5 Minuten aktualisiert)
 * WLAN-APs (readonly, per ping, alle 5 Minuten aktualisiert)
 * Server (readonly, per ping, alle 5 Minuten aktualisiert)
 * Türstatus (readonly, alle 5 Minuten aktualisiert)

Shutdown-Konzept
Per Default (z.B. nach einem Stromausfall) befindet sich das Dorf im Shutdown.

Shutdown einschalten

 * Klick auf Shutdown in dorfmap oder dreisekündiges Drücken des schwarzen Tasters am Spendenterminal (bis die grüne LED ausgeht)
 * Beleuchtung im Hackcenter geht sofort aus
 * Beleuchtung in der Schleuse (Logo und über der Tür) geht nach 1 bis 6 Minuten aus
 * Beleuchtung im Schaufenster leuchtet weiterhin, falls Nacht ist

Shutdown ausschalten

 * Klick auf Unshutdown oder irgendeine steuerbare Lampe in dorfmap oder dreisekündiges Drücken des schwarzen Tasters am Spendenterminal (bis die grüne LED angeht)
 * Falls eine Lampe angeklickt wurde, wird diese eingeschaltet
 * Beleuchtung in der Schleuse (Logo und über der Tür) geht nach 1 bis 6 Minuten an, falls Nacht ist; alternativ sobald die Sonne untergegangen ist