L's notes
T

Matrix [de]

9-11 minuten lesezeit

Inhalt:


Generelles

Matrix != Element. Das führt verständlicherweise oft zu Verwirrung. Matrix ist das protokoll, also wie nachichten versendet werden. Es gibt aber viele clients womit das protokoll benutzt wird, zB Element, Fluffy, Schildi und nheko. Kein mensch sagt "Ich schick dir 'ne Thunderbird nachicht" sondern es wird von eMail geredet, also dem protokoll und nicht dem client. Mit Matrix ist also das protokoll gemeint, mit Element der client.

...über Matrix und Element.

Zum Warum: ein Vergleich mit anderen Messengern.

Signal ist eine starke alternative, dank der zero-knowledge-archtektur fallen fast keine metadaten an. ABER:

  • es ist zwingend an eine Telefonnummer (damit eindeutig an eine Person) und ein Telefon (unsicher) gebunden,
  • es ist zentralisiert (was dem Autonomen Gedanken wiederspricht),
  • eine schnittstelle zu öffentlichen Telegram gruppen kann nicht mal so eben eingerichtet werden.
  • keine freie Software, sondern nur quelloffen.
>> FAQ: Ist das jetzt "sicher"?

Kommt drauf an.

Wenn chats verschlüsselt sind und alle beteiligten dicht halten: ja, sehr sogar.

Restrisioko: Wenn eine person mit staatstrojaner auf dem handy im chat ist, ist zwar der chatverlauf einsehbar, aber weil es keine telefonnummern gibt, sind beteiligte accounts nicht direkt personen zuzuordnen. Dieses restrisiko kann minimiert werden, indem menschen die wissen dass ein scheiszverein sie auf dem schirm hat weder android noch windows verwenden, sondern auf eine sicherere umgebung setzen. Siehe [[awesome-linux]].


Ersteinrichtung

Ich werde hier die schritte für Element beschreiben. Es gibt aber auch andere gute clients, zB SchildiChat (basiert auf element) und FluffyChat (minimalistischer), siehe einrichtung smartphones.

Grundsätzlich würde ich von einem Matrix.org Account abraten, weil ein großer Vorteil von Matrix dezentralisierung ist. Dein account ist bei einem kleineren homeserver besser aufgehoben.

Nun fragst du dich vielleicht welchen homeserver du statt matrix.org nehmen solltest. Hier habe ich mal einige aufgelistet, nimm einen der sich angenehm anfühlt. Die software (synapse) die drauf läuft ist bei allen gleich.



Öffentliche Server

Ungeprüft

Kriterien bei der recherche waren hohe uptime, eine aktuelle synapse version und kein oder ein großes upload limit. Ich habe aber kein account hier. Probier die ruhig mal aus und sag bescheid wie die so sind:

Keine infos (uptime, version, upload limit) gefunden

Tech Kollektive / Inis

Hier gibt's mehr als nur Matrix mit einem account. Du musst oft bevor du Matrix benutzen kannst ein generelles account erstellen.

  • feneas | feneas.org # offen
  • activism.international | activism.international # offen, incl. 10GB Nextcloud; XR und EG Hamburg nah
  • systemli | systemli.org # invite oder freundlich fragen :)
  • systemausfall | systemausfall.org # freundlich fragen :)
  • fff.chat | fff.chat # Von FFF Deutschland. Lokale OG Admins Fragen :)


Verschlüsselung

In Matrix gibt es vier keys (master, user, gerät; security key), praktischerweise musst du dich nur um einen kümmern. Das ist aber recht easy, außer wenn du deinen security key verschlampst und zusätzlich keine aktiven sessions mehr hast.

Das musst du machen:

  • 1 | Security key einrichten (beim ersten setup oder manuell in den "Einstellungen/Sicherheit")
  • 2 | Diesen SICHER (ohne dass andere rankommen, aber so, dass du immer rankommst) abspeichern, zB in einem sicheren Passwortmanager wie Bitwarden
  • 3 | KEYs NICHT VERLIEREN!

Idealerweise sollten deine sicherheitseinstellungen in Element etwa so aussehen:

Wenn der key fehlt, können alte (verschlüsselte) nachichten nicht entschlüsselt werden.

lost-keys

Warum so kompliziert

Nachrichten werden lokal auf dem gerät verschlüsselt, aber andere geräte in deinem account brauchen diese keys damit sie die Nachichten deiner anderen geräte lesen können. Mit dem security key machst du ein verschlüsseltes backup der geräte keys. Gleichzeitig muss ein gerät dieses backup auch lesen können, also muss es auch die keys erhalten.

Praktisch: So können leute die an deine account daten kommen nicht gleich alte nachichten entschlüsseln. Sollten angreifer versuchen den security key zurückzusetzen können die angreifende mit dem neuen key nicht die alten gerätekeys verwenden, weil sie ja mit dem alten security key verschlüsselt wurden. Deine nachichten sind also ziemlich sicher.

Für den fall dass du deinen key verschlampst (passiert den besten) solltest du von allen aktiven geräten die lokalen E2E keys als datei exportieren bevor du einen neuen security key generierst. Danach importierst du einfach die datei und die historie sollte wieder lesbar sein.

Wenn du das nicht machst (zb wenn dein gerät weg ist) dann kannst du mit den alten keys verschlüsselte Nachichten nicht lesen (siehe oben).

Für den fall, dass ein gerät eingesackt wird kannst du die entsprechende session zb vom PC aus sperren.

Um auf das warum zurück zu kommen: damit, auch wenn dein account oder ein gerät teilweise geknackt wurde, der chatverlauf noch sicher ist.

Sinnhaftigkeit von Verschlüsselung

Privatchats sollten immer verschlüsselt werden. Sensible, invite only gruppenchats auch.

Öffentlich gruppen zu verschlüsseln ist aber absoluter quatsch, denn (a) alle müssen für alle verschlüsseln, was ein heidenaufwand und riesiger keyaustausch ist und (b) in verschlüsselten chats funktionieren viele spaßige AppServices nicht (zB poll-bot oder die Telegram-bridge).

Verifikation

Du kannst mit anderen die Keys über emojis oder einen QR code scan abgleichen und so sicher sein, dass der account und seine keys auch wirklich zu der person gehört für die du sie hälst.



Smartphones

...sind grundsätzlich das absolut unsicherste ÜBERHAUPT und sollten für kritischen kram eigentlich so gar nicht verwendet werden, grade mit dem neuen abhörgesetz. Aber weil's halt einfach so praktisch ist:

Android

Element ist der standard. Es gibt auch eine F-Droid version, aber die bekommt keine push benachichtigungen, sondern fragt in regelmäßigen abständen den server nach neuen nachichten. Problem daran: das dauert eine weile und zieht viel akku.

Wenn du sehr an Apps wie WhatsApp oder Telegram gewöhnt bist, schau dir mal SchildiChat an. Das ist Element mit paar netten zusatz-features. Dabei aber drauf achten nicht einfach die normale F-Droid version zu nehmen, sondern vorher (wie auf der Website beschrieben) das repo hinzuzufügen, sonst fehlen (wie bei Element F-Droid) die push-benachichtigungen!

FluffyChat gibts auch, finde ich persönlich auch super. Hat aber leider keine raum widgets, was etwas unpraktisch ist. Hat aber schon eine implementation für sprachnachichten, was bei Element noch in Arbeit ist. F-Droid Version gibts natürlich auch hier.

IOS

Element ist momentan etwas scheiße auf IOS. Wenn etwas nicht funktioniert, überprüfe ob dein Matrix account an einem Single-Sign-On system hängt, bei tech-kollektiven ist das oft so. Mein letzter stand war, dass das die IOS-App SSO noch nicht konnte.

Fluffychat kann aber SSO, auch auf IOS.

Kein Speicherplatz?

Der (noch sehr neue) mobile-first webclient Hydrogen ist sehr schnell geladen und braucht keine installation, Mensch könnte sagen er ist leicht. Mmn sehr passend, immerhin ist Wasserstoff das leichteste element.

Wichtig: du musst die session manuell verifizieren, also deinen security key in den einstellungen einfügen. Wenn alles läuft schau ob Hydrogen push-benachichtigungen schicken darf und füge die Seite als verknüpfung oder PWA zu deiner app übersicht hinzu.

Limitationen: Du musst bereits ein Account haben um ihn zu benutzen. Du kannst mit Hydrogen (momentan) leider weder ein account erstellen, noch chats erstellen. Das ist aber in arbeit. Außerdem sollten SSO-Systeme vermieden werden.

Tipp: verwende nicht google chrome, sondern einen freien browser wie Bromite oder libre Firefox. Trackt weniger was du machst :)



Probleme / Troubleshooting

This message was not encrypted for your device

Encryption keys verschlampt. Schau ob (a) cross signing aktiviert ist (b) du auf einem anderen Gerät die Nachichten lesen kannst, wenn ja exportiere die e2e keys. Ggf hast du nie einen security key eingerichtet damit die e2e keys zwischen geräten ge-backupt werden können. Siehe Verschlüsselung

Widget: 403 Forbidden

Das kann an striktem verbieten von cross-site cookies im webbrowser leigen. Mach eine Ausnahme für enhanced tracking protection in firefox für den webclient.

Widgets setzen geht nicht

Ja, standardmäßig können das nur menschen ab power level 50 (moderator). Sag einer person die room permissions ändern kann bescheid, dass das auf PL 0 (Default) geändert werden sollte.

Ich bekomme keine Beanchichtigungen

Du hast safe die falsche app geladen, checke nochmal bei Smartphones/Android ob du die richtige App geladen hast. Bei Hydrogen oder Element-Web: schau in Smartphones/Kein Speicher ob du der Website erlaubt hast Benachichtigungen zu senden (WTF wie geht das: FF Desktop / FF Mobile | Bei anderen browsern ähnlich).



Anmerkungen / Feedback / Input

Fehler gefunden? Ergänzungen? Ideen? --> Ich freue mich über ein Github issue oder gleich eine Pull Request ^^

Show Graph Visualisation