LUKS beim Booten headless freischalten

Kategorien: administration

Moderne Prozessoren sind leistungsfähig genug, um eine Festplatte oder SSD komplett zu verschlüsseln. Eine verschlüsselte Festplatte macht es einem viel einfacher, sie ordnungsgemäß zu entsorgen. Klassisch habe ich die Festplatte mechanisch zerstört, bevor sie ins Recycling ging. Das ist aufwendig. Auch wenn man nicht paranoid ist, sollten die Datenträger also immer verschlüsselt werden.

Mehr lesen →

Dashboard-Server mit Freeboard einrichten

Kategorien: administration

Adafruit bietet für das Internet of Things einiges an. Besonders hat mir auf den ersten Blick der Dienst Adafruit.IO gefallen. Ruckzuck hatte ich einen Benutzer eingerichtet und einen ESP8266 mit PlattformIO programmiert. Mit dem Programmbeispiel sendet der ESP-01 alle fünf Sekunden einen Zählerwert. Der Wert wird schön in einem Graph im Dashboard auf adafruit.io angezeigt.

Beispiel eines adafruit.io Dashoards

Für den Unterricht ist der Dienst aber ungeeignet:

  • Die Schüler müssen einen Benutzer einrichten. Adafruit möchte dabei netterweise keine besonderen Daten.
  • Die Verfügbarkeit des Dienstes ist nicht garantiert.
  • Die Firewall der Schule lässt nur HTTP/HTTPS-Verkehr über einen Proxy mit Autorisierung durch. Damit können keine MQTT-Nachrichten das Schulnetz verlassen. Websockets habe ich nicht ausprobiert. Sie sind mir aber auch für die Vermittlung der Prinzipien zu aufwendig.
  • Der MQTT-Server liegt auf Github adafruit-io-node allerdings scheint die Version deutlich älter zu sein als der Dienst unter adafruit.io. Es fehlt auch das Dashboard und die Benutzerverwaltung.

Mehr lesen →

Eigenen Git-Server einrichten

Kategorien: administration

Im Unterricht möchte ich die Schülerinnen und Schüler an einem gemeinsamen Projekt arbeiten lassen. Dazu benötigen sie eine Versionsverwaltung. (Einfach ein Projekt auf Github dafür einzurichten scheidet aus. Da ein eigenes Konto auf Github einrichten müsste. Unterricht soll aber in einer kontrollierten Umgebung stattfinden.)

Alternativen

In der Vergangenheit habe ich deshalb mit Gitlab herumexperimentiert. Es war aber zu aufwendig, den Server stabil zu betreiben. Mehr oder weniger zufällig bin ich auf Gogs - Go Git Server gestoßen. Es gibt einen Fork des Projekts namens Gitea - Git with a cup of tea. Ich habe Gitea den Vorzug gegeben, da die Entwicklung von Gogs in der Vergangenheit eingeschlafen war. Gitea hat eine Menge Mitarbeiter, Gogs nur zwei. Allerdings sieht die Dokumentation von Gogs aufgeräumter aus. Momentan scheint der Unterschied zwischen Gogs und Gitea minimal zu sein.

Mehr lesen →

Zertifikate von Let’s Encrypt verwenden

Kategorien: administration

Installation von acme-tiny

Mein Favorit der Let's Encrypt Clients ist acme-tiny. Es ist ein sehr kurzes Python-Skript. Das erleichtert einen Code-Review. Die Vorarbeiten für die Zertifikatserstellung werden leicht mit OpenSSL durchgeführt. Es benötigt keine root-Rechte und funktioniert gut. In der folgenden Beschreibung gehen wir davon aus, dass der Benutzer lets als normaler Benutzer auf einem OpenBSD-System mit nginx als Web-Server existiert.

Erstellen der Verzeichnisstruktur

Im Verzeichnis des Benutzers lets wird folgende Verzeichnisstruktur angelegt.

Mehr lesen →