Benutzer-Werkzeuge

Webseiten-Werkzeuge


infrastruktur:portal300

Portal 300 | P300

Handbuch

tl;dr

  • WLAN: Portal-Dev (später: portal)
  • Aufschließen (Fronteingang): ssh open-front@portal.shackspace.de
  • Aufschließen (Hintereingang): nicht implementiert
  • Abschließen: ssh close@portal.shackspace.de
  • Statusabfrage: ssh status@portal.shackspace.de
  • Statusabfrage (maschinenlesbar): ssh status@portal.shackspace.de simple-status. Die möglichen Antworten stehen unten.
  • Alternative mit SSH command: Es kann jeder Benutzer auch als Befehl hinter einen anderen Benutzer geschrieben werden, hiermit können auch Apps wie Trigger bedient werden. Beispiel:
    • ssh status@portal.shackspace.de open-front
  • Türen
    • A: Die Holztüre an der Straße
    • B: Die Glastüre an der Straße
    • B2: Die innere Türe zum shackspace, an der Straße
    • C: Die Hintertüre auf dem Hof.
    • C2: Die innere Türe zum shackspace, Richtung Hof
  • shack-Zustände
    • open: shack ist aufgeschlossen und open for public
    • locked: Alle Türen sind abgeschlossen, shack ist zu.
    • unlocked via b2: Der shack ist aktuell nur über die Türe B2 betretbar.
    • unlocked via c2: Der shack ist aktuell nur über die Türe C2 betretbar.
    • unobserved: Die Sensoren haben noch keine ausreichenden Informationen für die Zustandserfassung geliefert.

Fehlerschießen

Initial-Fragen aus U300 Haustechnik

Die folgenden Punkte kommen ursprünglich aus der Liste U300 Haustechnik

  • wie viele und wo brauchen wir Motorschlösser?
  • Punkte, an die zu denken ist:
    • Türschloßantrieb z.B. Homematic
    • Entkernen, wir brauchen nur den Antrieb
    • Stromversorgung für den Motor und Zuführung zum Motor. Bitte für Türe und Rahmen minimalinvasiv ausführen /!\
    • Raspi mit WLAN, SD-Card & Stromversorgung jeweils für Raspi und Motor - Vorhanden sind: Raspi B+, WLAN-Adapter TL-WN725N, Türschloßantrieb
    • Kontakt für Türblatt und den Schließriegel. Bitte für Türe und Rahmen minimalinvasiv ausführen /!\
    • shack-status mit der Info des Kontakts in der Türfalle füttern
    • wollen wir beide Türen mit dem Portal kontrollieren oder nur eine? Welche?
    • Beide Türen zu den shack-Räumen haben 10..11mm Überstand des Schlisszylinders. Check.
    • Die Eingänge „B“ und „C“ sind über Buzzer zu öffnen. Es bedarf eines Relaiskontakts parallel zum Drücker an der Türsprechanlage.

Initialzustand Gebäudetechnik

  • In Raum 04 ist die Gegensprechanlage S, um die Tür zu öffnen
  • An Türe B ist ein (potentiell KNX-fähiger) Türöffner (ungeklärt, ob er KNX frisst)
  • Tür B1 ist nicht verschlossen
  • Tür B2 hat einen Schließzylinder
  • Türe C (Hintereingang) ist typischerweise abgeschlossen, ohne Türöffner (dürften Schlüssel nachmachen)
  • Türe C1 hat keinen Schließzylinder.
  • Türe C2 hat einen Schließzylinder.
  • Türe A1 ist eine Türe, die von innen immer geöffnet werden kann, aber von außen einen Schlüssel benötigt. Benötigt Hausschlüssel
  • Türe B ist eine Türe mit Schließzylinder und dem Hausschlüssel.
  • Als Türklingel m. Gegensprechanlage und Türöffner ist an Eingang B eine Busch-Welcome Anlage installiert.

Projektziel

  • Die shack-Vordertür (B2) wird wie in 0xFF mit RaspberryPi + Motorschloss geöffnet und geschlossen. Hierfür werden auch Reedkontakte für „Türe ist mechanisch zu“ sowie „Schließbolzen ist im Schloss“ benötigt.
  • Die shack-Hintertür (C2) wird wie die Vordertür mit einer Portalschaltung versehen
  • Wenn shack-Vordertür (B2) geöffnet wird, muss die Gebäude-Vordertür (B) mit der Buzzer-Schaltung für eine gewisse Zeit geöffnet werden. Dies sollte potentiell erst einige Sekunden nach dem Schließen der SSH-Verbindung enden, damit man Zeit hat, seine Geräte wieder zu verstauen und die Türe aufzudrücken
  • Für die Gebäude-Hintertür (C) muss eine technische Lösung etabliert werden, um diese auf/abschließen zu können, um Zugang zur shack-Hintertür (C2) zu erhalten
  • Die Klo-Tür (To) sowie die Zwischentüre (A1) müssen mit einem Klo-Button ähnlich dem in der 0xFF gelöst werden. Dies ist aber potentiell ein separates Projekt.

Fragen / Brainstorming

  • Hinter- und Vordertür sollten nicht synchron aufgeschlossen werden, aber zugeschlossen
  • Hierfür open@ für vorn, backdoor@ für hinten und close@ für „gesamten shack schließen“?
  • Portal-Einheiten müssen miteinander reden für synchronen Close-Request

Architektur

Das Portal der U300 besteht aus mehreren Komponenten, welche über MQTT miteinander kommunizieren:

  • MQTT-Broker
    Zentrale für Nachrichtenverteilung. Stellt zudem den WLAN-Zugang sowie DHCP/DNS zur Verfügung.
  • 2 Türsteuerung (Für Türen B2 sowie C2)
    Übernehmen die Steuerung einer Türe und überwachen die Sensorik.
  • Busch-Interface
    Reagiert auf Klingel-Signale und entsperrt die Türe B2.

MQTT-Nachrichten

Die MQTT-Nachrichten sind nun in der Software an einer zentralen Stelle dokumentiert.

Hardware & Elektronik

Initialzustand Motorschloss

eqiva 142950A0 (Key-BLE)

Mechanik

Für das vollständige Zerlegen benötigte Schraubendreher:

  • Sechskant 2.5mm
  • Torx T6

Elektronik

  • STM8L052C6-Prozessor (`STM8L052`, `C6T6, 99020, 07VG`, `MYS 99 936` )
  • CYW20736-Prozessor (`S`, `2007 G 15`, `CYP 604473`, `TWN`)
  • 2× Motor
    • Motor 1 dreht das Schloss aktiv auf und zu
    • Motor 2 betätigt eine mechanische Kupplung, welche Motor 1 und Schloss mechanisch trennen kann
  • 2× RP752G (`IOSB_`, `F7317`), potentiell HEXFET Power MOSFET für H-Brücke der beiden Motoren
  • Manuell implementierter Drehencoder(?) mit 2 Schaltern
  • Testpunkte für PRG1 (Proz: ???) und PRG2 (Proz: ???) verfügbar, vermutlich Programmierinterface für STM8L052C6 und CYW20736.
  • Versorgung via 3 * Mignon-AA-Zellen, also ca. 4.5V
    • 1mA Stromaufnahme im Standby
    • ~400mA Stromaufnahme bei dauerhafter Motorbewegung (unbelastet)
    • ~900mA Stromaufnahme bei Anfahren (unbelastet)
    • ~1000mA Stromaufnahme bei Blockieren
  • Motor fährt beim Anschalten kurzzeitig zurück, und anschließend in die gewünschte Richtung
  • Die Motoren werden direkt mit der Batteriespannung versorgt

Umbau Motorschloss

Das Motorschloss hat im Batteriefach jetzt Schraubklemmen, die die beiden Taster sowie die Stromversorgung (4.5V) bereitstellen.

Die Schalter SW0 und SW1 haben jeweils zwei Anschlüsse, hierbei ist + jeweils der aktive Schalteingang (active low) und - die jeweilige Masse des Schalters. Der Anschluss BAT erwartet zwischen - (GND) und + (VCC) 4.5 Volt. Hier ist zu klären, ob auch 5V Versorgungsspannung gehen.

Türsprechanlage Busch-Welcome

  • Busch-/ABB-Welcome Systemhandbuch
  • System controller ABB-Welcome 83300-5..
    • neben Tür B2
    • Türöffner (Tö) wird mit internen 12V~ versorgt. Für direkte Ansteuerung wäre also ein Wechselkontakt zur Vermeidung von Kurzschlüssen nötig.
    • Tö wird für 1s bis 10s (einstellbar an der Zentrale) aktiviert. Die Tür kann geöffnet werden, solange es „summt“.
    • Innenbus OUT1 ist im Rack 1-UG-2-2, AMP-Panel „51-100“, Port 21-25 aufgelegt und nach 1-UG-1-2 B022, B028, B046, und B089 gepatcht.
    • Innenbus OUT2 ist unbeschaltet. Restleistung von ~30W sollte für einen RPi reichen :)
  • Außenstation Busch-Jaeger 83101
  • Sprechstellen vom Typ 83205-AP-6xx Betriebsanleitung Bedienungsanleitung
    • Vermeintlich teildefekte Geräte (Klingel und Sprechverbindung gehen, Tö und Licht leuchtet lokal aber bewirkt nichts) können wiederbelebt werden: Es findet ein Handshake beim Systemboot statt → Sicherung F52

Terminal

Verbaut sind:

  • PIC16F1946
    • Klingelton-Speicher mit eingebautem Verstärker für Klingel-Lautsprecher
  • JRC NJM4558D: dual 741, siehe RC4558
    • Verstärker (und Filter/Mixer?) für Mikrofon
  • Jede Menge BC817-25 (NPN, 500mA) und BC807-25 (PNP, 500mA)
    • Vermutlich hauptsächlich Interface zur 2-Draht-Leitung

In einer Audio-Aufzeichnung direkt am Bus kann man etwas verstehen. Die massiven Störungen sind aber im Hörer nicht zu hören. Könnte Telefon-Filter 300-3400Hz sein oder sie nutzen nicht nur PAL-Video sondern auch den Ton-Träger bei 5.5MHz.

Die Kommunikation Terminal → Controller scheinen ~250mA Pulse zu sein. Gegenrichtung sieht in der Aufzeichnung ähnlich aus.

Modifikation

Innenansicht nach Modifikation: Tö-Kabel unten und Klingel-Signal oben

Der Tö-Taster ist an R72 angeschlossen und geht nach GND. Der Taster für die lokale Klingel arbeitet auch so. An der Steckverbindung ist DB_EX das aufbereitete (L, R, TVS-Diode) Signal. Achtung! GND könnte floating sein. Nicht mit a1 oder b1 mixen! → Klingel am Stecker herausgelöst und mit Kabel zu R72 ersetzt.

Auf dem „Power“-Modul war ein Relais nicht bestückt. Q1 schaltet die Versorgung des I2130SYI mit 3.3V solange an, wie die LED in der Tö-Taste blinkt. Die LED selber hat keine zugänglichen Lötpunkte auf der Bestückungsseite. → Ein SFH6156 Optokoppler hat auf den Relais-Pads eine ordentliche Klemme bekommen. Anode an Q1/D6 und Kathode über 270 Ohm an GND

Neue Klemmenbelegung:

  • a1
  • b1
  • Tö-Taster
  • GND für Tö-Taster
  • Emitter Optokoppler
  • Collector Optokoppler

Mit Brücken zwischen 3 und 6 sowie 4 und 5 öffnet Klingeln die Tür. An den ESP32 sollte also ein weiterer Optokoppler als „Taster“.

Es wurde ein ESP32 Board (WT32-ETH01) mit dem Busch-Welcome galvanisch getrennt verbunden. Die Kabelbelegung ist wie folgt:

  • Grau: GND
  • Orange: 5V
  • Gelb: Klingelsignal (Grau ist GND ref)
  • Braun: Emitter
  • Lila: Collector

Das Klingelsignal ist auf dem ESP als IO15 verfügbar (benötigt internen Pull-Up), die Türe kann via IO39 geschaltet werden.

Software & Architektur

Software-Entwicklung

Die Software wird aktuell auf GitHub entwickelt.

Prozesse

Die Gedanken hinter diesem Prozess sind folgende:

Es ist sinnvoller, immer erst eine Türe aufzuschließen und die zweite Tür nur dann zu öffnen, wenn die erste Türe tatsächlich benutzt wurde (also nicht nur aufgeschlossen ist, sondern auch geöffnet wurde).

Dies ist notwendig, dass der Fehlerfall „Türöffner funktioniert nicht“ abgefangen werden kann, denn niemand wird in dem Moment denken: „Oh, ich hab doch aber grade aufgeschlossen, die Tür im Gebäude ist ja noch offen“. Dies wird noch verstärkt durch das fehlende direkte Feedback (man steht auf der Straße und hört den Türmotor nicht arbeiten). Daher wird die Türe nur für 60 Sekunden aufgeschlossen, anschließend wird wieder abgeschlossen, außer die Türe wird in der Zwischenzeit geöffnet (Bestätigung von „Benutzer hat Gebäude erfolgreich betreteten“).

Beim Schließen können einfach beide Türen abgeschlossen werden, der shack kann aktuell sowieso nur durch die Türen A1, anschließend A zuverlässig verlassen werden. C ist potentiell abgschlossen.

Mechanik & Montage

Anforderungen

  • minimal invasiv im Hinblick auf die Mietsache
  • vollständig rückbaufähig
  • robust
  • mechanisch sachgerechter Aufbau
  • ohne Heissklebstoff, Klebeband, fliegende Leitungen o.ä. pfuschige Methoden

Kabelführung

  • Leitungen werden in Kabelkanälen geführt
  • um das Kabel zwischen Türe und Wand zu führen wird ein Kabelübergang verwendet.

Aufbau

p1090326-annotated.jpg

Legende

  • SWITCH01 - koppelt die Komponenten des Portal-LANs
    • APU
    • ESP32 „Control“
    • PoE-Injector #2
    • PoE-Injector #3
  • APU
    • WLAN-Accesspoint für SSID „Portal-Dev“
    • Zentrale Steuerung für
      • ESP32 Schloßantrieb Türe B2
      • ESP32 Schloßantrieb Türe C2
      • ESP32 „Control“
      • ESP32 „Status“
  • ESP32 „Control“
    • Interface zum Terminal („Telefon“)
    • Detektiert das Klingelsignal am Lautsprecher des Terminals
    • Löst den Türöffnerkontakt am Terminal aus
  • ESP32 „Status“
    • empfängt den Zustand des Portals via USB serial
    • übermittelt den Zustand des Portals über das shack-WLAN zum Internetservice
  • „Telefon“
    • Terminal zur Türsprechanlage
    • Wird vom ESP32 „Control“ gesteuert und überwacht
  • INJ#2
    • PoE-Injektor #2 für ESP32 Schloßantrieb Türe C2
  • INJ#3
    • Pseudo-PoE-Injektor #3 für ESP32 Schloßantrieb Türe B2

Trägersystem

p1090329-crop.jpg
p1090328-crop.jpg p1090327-annotated-crop.jpg

  • Die komplette OSB-Platte hängt mit einer Keilschiene an einem Querträger
  • Um die OSB-Platte abnehmen zu können müssen 5 Leitungen abgezogen werden:
    • Schukostecker der 6-fach Steckdosenleiste abziehen (roter Halbkreis)
    • RJ45-Stecker aus der Buchse „Tö“ abziehen (roter Kreis)
    • RJ45-Stecker aus der Buchse „BUS“ abziehen (roter Kreis)
    • RJ45-Stecker von Leitung „B2“ von „INJ#3“ abziehen (roter Kreis)
    • RJ45-Stecker von Leitung „C2“ von „INJ#2“ abziehen (roter Kreis)
  • Jetzt kann die Platte ca. 1.5cm angehoben, in Richtung Wand verschoben und dann abgenommen werden.
  • Das Terminal („Telefon“), der ESP32 „Control“ und die Wanddose „BUS“ / „Tö“ sind als Baugruppe auf einer Sperrholzplatte montiert und können mit zwei Schrauben (grüne Kreise) en bloc von der OSB-Platte getrennt werden.

Arbeitssitzungen

16.05.2022

Anwesende: xq, map, chris

  • Sichtung der vorhandenen Materialien
  • Drop von Relaiskarte, SD-Karte, Installationskabel (2- und 3-adrig, jeweils 20m), 8fach-Relaiskarte, 12V-zu-5V-USB-Netzteil
  • Reverse-Engineering des Motorschlosses
  • Umbau des vorhandenen Motorschlosses von (manuellem) Batteriebetrieb auf externe Stromversorgung+Schalter
  • Montage SD-Karte und WLAN-Adapter am RaspberryPi
  • Installation eines RaspberryPi OS auf der SD-Karte
    • Statische IP auf wlan0 eingerichtet (/etc/network/interfaces.d/wlan0)
    • ssh-Zugang aktiviert
    • Aktuell Defaultuser shack/shackit sowie root-User
    • Setup-Versuch von HostAPD, scheitert aber an „interface wlan0 not up.“

07.06.2022

Anwesende: xq, m1k3y, stefan, chris

  • Material wurde von Chris organisiert
    • Ausreichend Reedkontakte für Einbau- und Oberflächenmontage
  • APUs wurden auf Funktionsfähigkeit geprüft
    • WLAN: gut
    • Problem: GPIOs: Unbenutzbar, es gibt keine funktionierenden Treiber
    • Lösung: Wir benutzen den RPI als IO-Device, die APU als WLAN-AP
  • Es wurde versucht, das WLAN auf dem RPI funktionsfähig zu machen
    • Problem: Unmöglich mit vorhander WLAN-HW, da kein Support in HostAPD sowie Kernel für WLAN-Modul
    • Lösung: APU macht MQTT-Broker, WLAN (ggf. mit Captive Portal), DHCP und DNS im Portal-Netzwerk
  • Diskussion über die User-Workflows mit dem Portal sowie die Abläufe in der Software
  • Türöffner-Ansteuerung und Türklingel-Auslese wurde erfolgreich gehackt
    • Hierfür wurde von kr4bat ein ESP32 mit Ethernet organisiert
  • Motorschloss wurde an Fronttür(B2) montiert
  • GPIO-Library wurde in Portal-Software integriert und notwendige GPIOs identifiziert
  • Tür-Ersatz wurde gelötet, um Software zu testen (Drei Buttons, zwei LEDs auf kleiner Platine)

12.06.2022

Anwesende: xq, stefan

  • Die GPIOs vom Pi wurden lauffähig gemacht
  • Es wurde die Ablauf-Sequenz für ÖFFNEN und SCHLIESSEN definiert und implementiert
  • Der ESP32 wurde erfolgreich mit der Sprechstelle verheiratet

13.06.2022

Anwesende: xq, m1k3y

  • Die APU wurde vorbereitet
    • WLAN, DHCP, DNS eingerichtet
    • MQTT-Server installiert
    • Experimente mit Captive Portal, es wird leider nicht so einfach, Android von gutem Verhalten zu überzeugen. Apple ist da gemütlicher
  • Ein neuer Key-Export-Prozess wurde definiert
  • Key-Export aus dem Byro wurde implementiert
  • authorized_keys erzeugen wurde implementiert
  • Signieren und Verifizieren der Signatur mit openssl wurde getestet
  • Neues Konzept für Türsteuerungen: Statt RPI wird nun ein ESP32 benutzt, SSH terminiert nur auf der APU
    • 4 weitere ESP32-Boards wurden bestellt

18.06.2022

Anwesende: xq, m1k3y, stefan

  • Die Portal-Software wurde auf die APU deployed.
  • Es wurde ein Script zum automatischen Import eines Key-Exports entwickelt.
  • Umbau der beiden Software-Repositories in ein großes Monorepo.
  • Ein ESP wurde erfolgreich in die Busch Welcome-Interface integriert.
  • Es wurde eine Platine für die Motorsteuerung gelötet.
  • Motor-Steuerung wurde mechanisch reperiert, Freilauf funktioniert jetzt wieder zuverlässig.
  • Integrations-Versuch von Motorsteuerung, Busch Welcome-Interface sowie des Daemons.
  • Motor-Stromaufnahme wurde noch einmal mit besserem Messgerät verifiziert.

Es wurde folgende Projektziele erreicht:

  • Die Fronttüre B kann nun per SSH geöffnet werden!
  • Die Fronttüre B kann nun per Klingel geöffnet werden, wenn der shack als aufgeschlossen gilt.

2022-09-09

Anwesende: xq, chris, jens, stefan

  • Montage des Trägers für den Magneten des Sensors zur Erkennung der Position des Türblatts und des Magneten selbst

2022-09-10

Anwesende: xq, stefan, chris

  • Einbau von Magneten & Hallsensoren in die Einsteckschlösser zur Erkennung der Position der Schließriegel

2022-12-25

Anwesend: c-mon

  • Usability-Verbesserung für legacy-user. Beim Login über open@portal.portal wird jetzt ein nützlicher Hinweis auf den neuen Login-Prozess angezeigt.

2022-12-25

Anwesend: c-mon, chris

  • Usability-Verbesserung für legacy-user:
    • Zeichen am Wegesrand für die Kinder Israels.
      • User „open“, für Legacy-Meldung:
        • in /etc/passwd: open:x:1007:1007::/home/open:/bin/false
        • in /etc/group: open:x:1007:
      • Meldung ausgeben, dass der User „open“ nicht mehr besteht:
/etc/ssh/sshd_config.d/banner-open.conf
# set explanatory message for legacy login user:
Match User open
        Banner /etc/ssh/banner-open
        PasswordAuthentication No
/etc/ssh/banner-open
## Dear legacy-user,
## 
## login using the user "open" is no longer supported.
## Please log in with 
##     "open-front" 
## for opening the front door or 
##     "open-back"
## for opening the back door.
## 
## For more information read the documentation at https://wiki.shackspace.de/infrastruktur/portal300
## Farewell,
## open
  • damit als DNS-Name portal.portal UND portal.shackspace.de funktionieren:
    • in /etc/hosts eintragen:
      192.168.77.1 portal.portal portal.shackspace.de
  • ein Eintrag server=… in /etc/dnsmasq.conf ist nicht erforderlich.

2022-12-26

Anwesend: chris

Zeitstempel in der shell-history eingefügt. Dazu in /root/.bashrc und /home/loginuser/.bashrc eingetragen: HISTTIMEFORMAT=„%F %T “. Klappt natürlich erst ab sofort, zurückliegende Einträge werden mit dem Modification Date von .bash_history gelistet. Wird i.L.d.Z herausrotieren…

2023-01-29

  • Anwesend: Stefan, Andreas, chris
  • Montage eines Trägers oberhalb Türe B2
  • Montage der Komponenten APU, Switch, ESP32, Steckdosenleiste auf ein Board
  • Kabelzuführungen aus dem Schrank neben B2 in die Decke oberhalb B2
  • ToDo:
    • „Telefon“ auf das Board montieren
    • Kabelverbindungen herstellen
    • Board in den Träger oberhalb B2 einhängen

2023-01-29

  • Anwesend: Stefan, Karl, Raute, chris
  • Montage der Komponenten „Telefon“, ESP32, RJ45-Buchsen auf ein Modulboard
  • Modulboard & Netzteile auf dem Haupt-Board montiert
  • Kabelverbindungen hergestellt
  • Board in den Träger oberhalb B2 eingehängt
  • Ergebnis:
    • die Portal-Steuerung ist jetzt komplett oberhalb B2 montiert
    • der Aufbau ist modular und kann für Wartung und Fehlersuche einfach abgebaut werden

2024-03-25

  • Anwesend: chris
  • Montage und Anschluß des ABUS-Reedkontakts und des zugehörigen Magneten an Türe C2.

nächste Schritte

  • Umzug der Hardware in die Werkstatt
  • Statemachine der Firmware auf neues Modell umschreiben
  • Zweite Hardware fertig stellen
    • Magnetsensor an der Türe anbringen
    • Elektronik bespaßen
    • Verkabelung organisieren
  • System-Reset via MQTT implementieren
  • Debug-Interface implementieren
    • Dazu auch: LEDs einbauen, die Zustände anzeigen, z.B.
      • Anliegen von Betriebsspannungen
      • Seriell in die Ansteuerung der Optokoppler
  • Vorstands-Scripte fertigstellen
  • Portal-Box clean aufsetzen
  • Neue CA erzeugen und neue Keys deployen
infrastruktur/portal300.txt · Zuletzt geändert: 2024-07-06 14:03 von chris