/* Hardware Basteln und Programmieren */
[stratum0-wiki.git] / Space-Status.mw
1 {{Projekt
2 |verantwortlich=[[Benutzer:Daniel Bohrer|Daniel Bohrer]]
3 |status=aktiv
4 |beschreibung=Anzeige/Bereitstellung des Space-Öffnungsstatus
5 |source=[https://github.com/stratum0/StratumOpenCloseMonitor GitHub]
6 }}
7
8 == Idee ==
9 Da nicht alle Mitglieder einen Schlüssel haben können, wird an diversen Stellen angezeigt, ob der Space gerade offen ist.
10
11 == Momentane Situation ==
12 Der Status kann im Moment nur per Hand aus dem [[IRC]] über die Befehle <tt>sudo auf</tt> bzw. <tt>sudo zu</tt> (alleine am Anfang einer Zeile) gesetzt werden. Die Befehle veranlassen unseren IRC-Bot [[StratumGuardian]], das Topic im IRC-Channel zu setzen (hier ist insbesondere wichtig, dass nach dem ersten und dem zweiten Vorkommen der Zeichenfolge <tt>||</tt> gesucht wird, und alles dazwischen durch den Status ersetzt wird).
13
14 {{Hinweis|Es wird auch der Nickname desjenigen ins Topic geschrieben, der den Status auf „offen“ gesetzt hat. Die Konvention ist, dass diese Person dafür verantwortlich ist, den Status wieder auf „zu“ zu setzen, oder die Verantwortung dafür an eine andere Person weiterzugeben. '''Falls der Space-Status auf „offen“ steht und Leute längere Zeit vor verschlossener Tür stehen, schuldet der Verantwortliche diesen Leuten je drei Flaschen Club-Mate.'''}}
15
16 Das aktuelle (manipulationsanfällige) System soll in Zukunft durch einen Hardwareschalter zum Öffnen und Schließen im Space ersetzt werden, siehe [[/Hardware]].
17
18 === Anzeige ===
19 Der Öffnungsstatus wird menschenlesbar auf 5 Minuten genau an folgenden Stellen angezeigt:
20 * im Topic des [[IRC]]-Channels
21 * hier im Wiki links in der Seitenleiste
22 * an der Tür oben auf einem 3.5"-Display
23 * als bookmarkbare Version ohne viel Wiki-Overhead: https://status.stratum0.org/status.html
24 * als Graph mit der Anzahl der Tage im Bezug auf die Tageszeit: http://hackt-im-stratum0.org/graphen/s0zeiten.png
25 * als Statistik über die aggregierte Öffnungszeit: http://spaceapi.bastinat0r.de/#stratum0
26
27 === API ===
28 Im Artikel [[/API]] wird die API beschrieben, über die der Status maschinell ausgelesen werden kann. Für die Statistik gibt es ein Archiv der bisherigen offen/zu-Befehle inkl. Timestamps: https://status.stratum0.org/archive.txt
29
30 Die hackerspaceübergreifende [http://spaceapi.net SpaceAPI] wird unterstützt. Die entsprechende Endpoint-URL ist http://status.stratum0.org/status.json.
31
32 === SpaceVoice ===
33 Um die reale Welt in der virtuellen Welt abzubilden, bekommen im Space anwesende Entitäten im [[Chat|IRC-Channel]] das Voice-Flag (+v). Das funktioniert auf Basis von {{Wikipedia|Internet Control Message Protocol|ICMP}}-Pings oder {{Wikipedia|mDNS}}-Hostnamen, die alle fünf Minuten im LAN detektiert werden. Um erkannt zu werden, müssen Entitäten eine oder mehrere ihrer MAC-Adressen oder mDNS-Hostnamen an [[Benutzer:Daniel Bohrer|Daniel Bohrer]] melden, der sie dann im System hinzufügt.
34
35 === Systemdokumentation ===
36
37 Auf dem [[Plenum 2012-08-22]] gab es einen kurzen Vortrag über die Funktionsweise mit Beschreibung des aktuellen Stands und Ausblick für die Zukunft.
38
39 * [[:Media:Open-close-Monitor 2012-08-06.pdf|Vortragsfolien]]
40
41 tl;dr: Plugin für IRC-Bot ist [https://github.com/stratum0/StratumOpenCloseMonitor hier], das schreibt nginx-Config, nginx serviert status.png jeweils mit HTTP-302-Redirect auf closed.png oder open.png. Das ganze läuft auf einem Raspberry Pi im Space.
42
43 == Apps ==
44 Es gibt mehrere Apps, um den Space-Status anzuzeigen:
45 * [[StratumsphereStatusWidget]] für Android
46 * [[StratumsphereTrayIcon]] für Linux, Windows und Mac OS X
47 * indirekt über die SpaceAPI werden auch etsprechende [http://spaceapi.net/app Apps] unterstützt.
48
49 == Elektronische Türöffnung ==
50 Eine elektronische Türöffnung wird im Artikel [[Spacegate]] geplant.
51
52 == To Do ==
53 * <s>[[EVENTDISTR]]-Pakete senden</s> done in [https://github.com/stratum0/StratumOpenCloseMonitor/commit/2cf610db37da4c62963b00520352a489e699de4a 2cf610db]
54 * Rewrite des SpaceVoice-Teils, vollständig als Daemon/cronjob (im Moment im supybot-Plugin realisiert, hat da eigentlich nichts zu suchen.)
55 * Aufmachen, wenn mindestens n Entitäten anwesend sind?
56 * Space-Voice: mDNS hat langen Timeout, wenn Geräte sich nicht explizit abmelden. Möglicherweise zusätzlich pingen und bei fehlendem Ping Geräte aus der Liste werfen
57 * nmap findet manchmal nicht alle pingbaren MAC-Adressen… Timeout erhöhen? nmap nachbauen für mehr Flexibilität?
58 * Rewrite mit Python Twisted für saubere API auch nach innen, mehr Flexibilität und einfachere Wartbarkeit
59
60 == Ähnliche Systeme ==
61 * Der [http://shackspace.de/wiki/doku.php?id=shack_open_close_monitor shack open/close monitor] aus Stuttgart
62 * [https://www.das-labor.org/wiki/Status-Bot Status-Bot], Bochum --[[Benutzer:Sensorpixel|Sensorpixel]] 17:54, 13. Jan. 2012 (UTC)
63
64 [[Kategorie:Infrastruktur]]
This page took 0.052683 seconds and 5 git commands to generate.