Merge branch 'main' of github.com:SebastianObi/LXMF-Tools

This commit is contained in:
SebastianObi 2023-10-15 08:52:18 +02:00
commit 50fda242de
13 changed files with 2668 additions and 0 deletions

196
README_de.md Normal file
View File

@ -0,0 +1,196 @@
# LXMF-Tools
Verschiedene kleine Programme und Tools, die das Nachrichtenprotokoll LXMF verwenden von https://github.com/markqvist/LXMF
## lxmf_bridge_matrix
Weitere Informationen finden Sie in der ausführlichen [README.md](lxmf_bridge_matrix).
## lxmf_bridge_meshtastic
Weitere Informationen finden Sie in der ausführlichen [README.md](lxmf_bridge_meshtastic).
## lxmf_bridge_mqtt
Dieses Programm bietet eine Schnittstelle zwischen LXMF und MQTT. Es dient als Endpunkt für einzelne Nachrichten und nicht dazu, den LXMF/Reticlum-Verkehr 1:1 an MQTT zu übertragen. Es dient dem Zweck, einen Endpunkt im Reticulum-Netzwerk für Anwendungen von Drittanbietern bereitzustellen, die über MQTT kommunizieren können. Über diesen können alle LXMF-fähigen Anwendungen über Nachrichten mit ihm kommunizieren. Dies kann z.B. genutzt werden, um über Textnachrichten mit einem Smarthome-System (FHEM, openHAB, ioBroker, Node-RED o.ä.) zu kommunizieren. Das von MQTT verwendete Übertragungsformat ist JSON mit frei definierbaren Topics. Das Zielsystem kann dann auf diese JSON-Nachrichten antworten.
Weitere Informationen finden Sie in der ausführlichen [README.md](lxmf_bridge_mqtt).
## lxmf_bridge_telegram
Weitere Informationen finden Sie in der ausführlichen [README.md](lxmf_bridge_telegram).
## lxmf_chatbot
Dieses Programm bietet einen einfachen Chatbot (RiveScript), der über LXMF kommunizieren kann.
Weitere Informationen finden Sie in der ausführlichen [README.md](lxmf_chatbot).
## lxmf_cmd
Dieses Programm führt jeden per Nachricht empfangenen Text als Systembefehl aus und gibt die Ausgabe des Befehls als Nachricht zurück. Es können nur einzelne Befehle direkt ausgeführt werden. Es wird kein interaktives Terminal erzeugt.
Weitere Informationen finden Sie in der ausführlichen [README.md](lxmf_cmd).
## lxmf_distribution_group
Dieses Programm bietet eine E-Mail-ähnliche Verteilergruppe. Es verteilt eingehende LXMF-Nachrichten an mehrere Empfänger. Da dieses Programm wie ein normaler LXMF-Endpunkt agiert, können alle kompatiblen Chat-Anwendungen verwendet werden. Zusätzlich zum einfachen Messaging gibt es eine einfache kommandobasierte Benutzeroberfläche. Hier können alle relevanten Aktionen für die tägliche Verwaltung durchgeführt werden. Die Grundkonfiguration wird in den Konfigurationsdateien vorgenommen. Es gibt verschiedene Optionen, um das gesamte Verhalten der Gruppe an die eigenen Bedürfnisse anzupassen. Diese Verteilergruppe ist viel mehr als eine Standard-E-Mail-Verteilergruppe. Sie emuliert erweiterte Gruppenfunktionen mit automatischen Benachrichtigungen usw. Es können verschiedene Benutzerberechtigungen definiert werden. Für jeden Benutzertyp kann der Funktionsumfang individuell festgelegt werden. Die normalen Benutzer haben nur geringe Rechte. Während ein Moderator oder Admin mit einfachen Befehlen alles Notwendige erledigen kann. Ist die Grundkonfiguration einmal erledigt, kann alles Weitere über LXMF-Nachrichten als Befehle erfolgen.
Weitere Informationen finden Sie in der ausführlichen [README.md](lxmf_distribution_group).
## lxmf_distribution_group_minimal
Dieses Programm ist eine minimalistische Version der normalen Verteilungsgruppe. Die Funktionalität ist auf ein Minimum reduziert. Es können nur Absender und Empfänger definiert werden. Die Nachrichten werden dann entsprechend an die anderen Benutzer gesendet. Es gibt keine Benutzeroberfläche oder sonstige Benachrichtigungen. Lediglich die Nachrichten werden 1:1 verteilt. Die Verwaltung erfolgt komplett über die jeweiligen Konfigurationsdateien, die entsprechend zu bearbeiten sind.
Weitere Informationen finden Sie in der ausführlichen [README.md](lxmf_distribution_group_minimal).
## lxmf_echo
Dieses Programm ist ein einfacher Echo-Server. Alle empfangenen Nachrichten werden 1:1 als Antwort zurückgeschickt. Es kann als einfaches Gegenstück verwendet werden, um die Chat-Funktionalität von Anwendungen zu testen.
Weitere Informationen finden Sie in der ausführlichen [README.md](lxmf_echo).
## lxmf_ping
Dieses Programm sendet eine einstellbare Anzahl von LXMF-Nachrichten an ein Ziel. Anschließend wird eine einfache Statistik erstellt, um den Erfolg oder Misserfolg einer einzelnen Nachricht zu überprüfen. Dieses Tool kann nützlich sein, um das LXMF/Reticulum-Netzwerk mit einer bestimmten Anzahl von Nachrichten zu belasten. Damit lässt sich eine bestimmte Anzahl von Benutzern simulieren.
Weitere Informationen finden Sie in der ausführlichen [README.md](lxmf_ping).
## lxmf_terminal
Dieses Programm bietet eine vollständige Terminalsitzung auf dem Server. Es können beliebige Befehle auf dem Zielgerät ausgeführt werden. Die Kommunikation erfolgt über einzelne LXMF-Nachrichten. Dies bietet den Vorteil, dass einfache Terminalbefehle von jeder LXMF-fähigen Anwendung genutzt werden können.
Weitere Informationen finden Sie in der ausführlichen [README.md](lxmf_terminal).
## Allgemeine Informationen für alle Tools/Programme
### Aktueller Stand:
Es handelt sich derzeit um eine Betasoftware, die noch in Arbeit ist.
Alle Kernfunktionen sind implementiert und funktionieren, aber Ergänzungen werden wahrscheinlich auftreten, wenn die reale Nutzung erforscht wird.
Es kann zu Fehlern kommen oder die Kompatibilität nach einem Update ist nicht mehr gewährleistet.
Die vollständige Dokumentation ist noch nicht verfügbar. Aus Zeitmangel kann ich auch nicht sagen, wann diese weiterbearbeitet werden wird.
### Installation:
- Installieren Sie alle erforderlichen Voraussetzungen.
(Standardinstallation von Reticulum. Nur erforderlich, wenn Reticulum noch nicht installiert ist).
```bash
apt update
apt upgrade
apt install python3-pip
pip install pip --upgrade
reboot
pip3 install rns
pip3 install pyserial netifaces
pip3 install lxmf
```
- Ändern Sie die Reticulum-Konfiguration entsprechend Ihren Anforderungen und Ihrem Anwendungsfall.
```bash
nano /.reticulum/config
```
- Laden Sie die [Datei](lxmf_distribution_group.py) aus diesem Repository herunter.
```bash
wget https://raw.githubusercontent.com/SebastianObi/LXMF-Tools/main/lxmf_distribution_group/lxmf_distribution_group.py
```
- Machen Sie es mit folgendem Befehl ausführbar
```bash
chmod +x lxmf_distribution_group.py
```
### Starten:
- Starten Sie
```bash
./lxmf_distribution_group.py
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
- Beispiel einer Minimalkonfiguration (Überschreibung der Standardkonfiguration `config.cfg`). Dies sind die wichtigsten Einstellungen, die angepasst werden müssen. Alle anderen Einstellungen stehen in der `config.cfg`.
```bash
nano /root/.lxmf_distribution_group/config.cfg.owr
```
- Starten Sie erneut. Fertig!
```bash
./lxmf_distribution_group.py
```
### Als Systemdienst/Dämon ausführen:
- Erstellen einer Servicedatei.
```bash
nano /etc/systemd/system/lxmf_distribution_group.service
```
- Kopieren Sie den folgenden Inhalt und passen Sie ihn an Ihre eigenen Bedürfnisse an.
```bash
[Unit]
Description=lxmf_distribution_group.py Daemon
After=multi-user.target
[Service]
# ExecStartPre=/bin/sleep 10
Type=simple
Restart=always
RestartSec=3
User=root
ExecStart=/root/lxmf_distribution_group.py
[Install]
WantedBy=multi-user.target
```
- Aktivieren Sie den Dienst.
```bash
systemctl enable lxmf_distribution_group
```
- Starten Sie den Dienst.
```bash
systemctl start lxmf_distribution_group
```
### Starten/Stopen des Dienstes:
```bash
systemctl start lxmf_distribution_group
systemctl stop lxmf_distribution_group
```
### Dienst aktivieren/deaktivieren:
```bash
systemctl enable lxmf_distribution_group
systemctl disable lxmf_distribution_group
```
### Mehrere Instanzen ausführen (Kopieren der gleichen Anwendung):
- Starten Sie das Programm mit einem anderen Konfigurationspfad.
```bash
./lxmf_distribution_group.py -p /root/.lxmf_distribution_group_2nd
./lxmf_distribution_group.py -p /root/.lxmf_distribution_group_3nd
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
## Support / Donations
Sie können die weitere Entwicklung unterstützen, indem Sie über einen der folgenden Kanäle spenden:
- PayPal: https://paypal.me/SebastianObi
- Liberapay: https://liberapay.com/SebastianObi/donate
## Unterstützen Sie auf andere Weise?
Sie sind herzlich eingeladen, sich an der Entwicklung zu beteiligen. Erstellen Sie einfach einen Pull-Request. Oder kontaktieren Sie mich einfach für weitere Klärungen.
## Benötigen Sie eine spezielle Funktion oder Anpassung?
Dann nehmen Sie Kontakt mit mir auf. Speziell für Sie entwickelte Anpassungen oder Tools können realisiert werden.
## FAQ

View File

@ -0,0 +1,5 @@
# lxmf_bridge_matrix
Weitere Informationen finden Sie in den Konfigurationsoptionen (am Ende der Programmdateien).
Alles Weitere ist dort kurz dokumentiert.
Nach dem ersten Start wird diese Konfiguration als Standardkonfiguration in der entsprechenden Datei angelegt.

View File

@ -0,0 +1,5 @@
# lxmf_bridge_meshtastic
Weitere Informationen finden Sie in den Konfigurationsoptionen (am Ende der Programmdateien).
Alles Weitere ist dort kurz dokumentiert.
Nach dem ersten Start wird diese Konfiguration als Standardkonfiguration in der entsprechenden Datei angelegt.

View File

@ -0,0 +1,223 @@
# lxmf_bridge_mqtt
Dieses Programm bietet eine Schnittstelle zwischen LXMF und MQTT.
Es dient als Endpunkt für einzelne Nachrichten und nicht dazu, den LXMF/Reticlum-Verkehr 1:1 an MQTT zu übertragen.
Es dient dem Zweck, einen Endpunkt im Reticulum-Netzwerk für Anwendungen von Drittanbietern bereitzustellen, die über MQTT kommunizieren können.
Über diesen können alle LXMF-fähigen Anwendungen über Nachrichten mit ihm kommunizieren.
Dies kann z.B. genutzt werden, um über Textnachrichten mit einem Smarthome-System (FHEM, openHAB, ioBroker, Node-RED o.ä.) zu kommunizieren.
Das von MQTT verwendete Übertragungsformat ist JSON mit frei definierbaren Topics.
Das Zielsystem kann dann auf diese JSON-Nachrichten antworten.
Weitere Informationen finden Sie in den Konfigurationsoptionen (am Ende der Programmdateien).
Alles Weitere ist dort kurz dokumentiert.
Nach dem ersten Start wird diese Konfiguration als Standardkonfiguration in der entsprechenden Datei angelegt.
### Features
- Kompatibel mit allen LXMF-Anwendungen (NomadNet, Sideband, ...)
- Kompatibel mit allen MQTT-Servern
## Beispiele für die Verwendung
###
### Allgemeine Information, wie die Nachrichten transportiert werden
Alle Nachrichten zwischen Client<->Server werden als einzelne 1:1 Nachrichten im LXMF/Reticulum Netz transportiert.
Dementsprechend findet zwischen diesen Endpunkten eine Verschlüsselung statt.
Wenn eine direkte Zustellung der Nachricht nicht funktioniert, wird sie an einen Propagationsknoten gesendet.
Dort wird sie zwischengespeichert und kann später vom Client abgerufen werden.
Da es sich um normale LXMF-Nachrichten handelt, kann jede LXMF-fähige Anwendung zur Kommunikation mit der Gruppe verwendet werden.
## Aktueller Status
Es handelt sich derzeit um eine Betasoftware, die noch in Arbeit ist.
Alle Kernfunktionen sind implementiert und funktionieren, aber Ergänzungen werden wahrscheinlich auftreten, wenn die reale Nutzung erforscht wird.
Es kann zu Fehlern kommen oder die Kompatibilität nach einem Update ist nicht mehr gewährleistet.
Die vollständige Dokumentation ist noch nicht verfügbar.
Aus Zeitmangel kann ich auch nicht sagen, wann diese weiterbearbeitet werden wird.
## Screenshots / Beispiele für den Gebrauch
<img src="../docs/screenshots/lxmf_bridge_mqtt_01.png" width="200px">
## Installations Handbuch
### Installation:
- Installieren Sie alle erforderlichen Voraussetzungen. (Standardinstallation von Reticulum. Nur erforderlich, wenn Reticulum noch nicht installiert ist).
```bash
apt update
apt upgrade
apt install python3-pip
pip install pip --upgrade
reboot
pip3 install rns
pip3 install pyserial netifaces
pip3 install lxmf
```
- Ändern Sie die Reticulum-Konfiguration entsprechend Ihren Anforderungen und Ihrem Anwendungsfall.
```bash
nano /.reticulum/config
```
- Laden Sie die [Datei](lxmf_bridge_mqtt.py) aus diesem Repository herunter.
```bash
wget https://raw.githubusercontent.com/SebastianObi/LXMF-Tools/main/lxmf_bridge_mqtt/lxmf_bridge_mqtt.py
```
- Machen Sie es mit folgendem Befehl ausführbar
```bash
chmod +x lxmf_bridge_mqtt.py
```
### Starten:
- Starten Sie
```bash
./lxmf_bridge_mqtt.py
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen.
Der Speicherort der Datei wird angezeigt.
- Beispiel einer Minimalkonfiguration (Überschreibung der Standardkonfiguration `config.cfg`).
Dies sind die wichtigsten Einstellungen, die angepasst werden müssen.
Alle anderen Einstellungen stehen in der `config.cfg`.
```bash
nano /root/.lxmf_bridge_mqtt/config.cfg.owr
```
```bash
```
- Starten Sie erneut. Fertig!
```bash
./lxmf_bridge_mqtt.py
```
### Wird als Systemdienst/Damon ausgeführt:
- Erstellen Sie eine Servicedatei.
```bash
nano /etc/systemd/system/lxmf_bridge_mqtt.service
```
- Kopieren Sie den folgenden Inhalt und passen Sie ihn an Ihre eigenen Bedürfnisse an.
```bash
[Unit]
Description=LXMF Bridge MQTT Daemon
After=multi-user.target
[Service]
# ExecStartPre=/bin/sleep 10
Type=simple
Restart=always
RestartSec=3
User=root
ExecStart=/root/lxmf_bridge_mqtt.py
[Install]
WantedBy=multi-user.target
```
- Aktivieren Sie den Dienst.
```bash
systemctl enable lxmf_bridge_mqtt
```
- Starten Sie den Dienst.
```bash
systemctl start lxmf_bridge_mqtt
```
### Dienst starten/stoppen:
```bash
systemctl start lxmf_bridge_mqtt
systemctl stop lxmf_bridge_mqtt
```
### Dienst aktivieren/deaktivieren:
```bash
systemctl enable lxmf_bridge_mqtt
systemctl disable lxmf_bridge_mqtt
```
### Mehrere Instanzen ausführen (um dieselbe Anwendung zu kopieren):
- Führen Sie das Programm mit einem anderen Konfigurationspfad aus.
```bash
./lxmf_bridge_mqtt.py -p /root/.lxmf_bridge_mqtt_2nd
./lxmf_bridge_mqtt.py -p /root/.lxmf_bridge_mqtt_3nd
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
### Erste Verwendung:
- Bei einem manuellen Start über die Konsole wird die eigene LXMF-Adresse angezeigt:
```
[] ...............................................................................
[] LXMF - Address: <801f48d54bc71cb3e0886944832aaf8d>
[] ...............................................................................`
```
- In der Standardeinstellung wird diese Adresse auch beim Start bekannt gegeben.
- Nun kann die Software verwendet werden.
### Parameter für die Inbetriebnahme:
```bash
usage: lxmf_distribution_group_minimal.py [-h] [-p PATH] [-pr PATH_RNS] [-pl PATH_LOG] [-l LOGLEVEL] [-s] [--exampleconfig]
[--exampleconfigoverride] [--exampledata]
LXMF Distribution Group - Server-seitige Gruppenfunktionen für LXMF-basierte Anwendungen
optionale Argumente:
-h, --help diese Hilfemeldung anzeigen und beenden
-p PATH, --path PATH Pfad zum alternativen Konfigurationsverzeichnis
-pr PATH_RNS, --path_rns PATH_RNS
Pfad zum alternativen Reticulum-Konfigurationsverzeichnis
-pl PATH_LOG, --path_log PATH_LOG
Pfad zum alternativen Protokollverzeichnis
-l LOGLEVEL, --loglevel LOGLEVEL
-s, --service Läuft als Dienst und sollte in der Datei loggen
--exampleconfig Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
--exampleconfigoverride
Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
--exampledata Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
```
### Configurationsdaten Dateien:
- config.cfg
Dies ist die Standardkonfigurationsdatei.
- config.cfg.owr
Dies ist die Benutzerkonfigurationsdatei, die die Standardkonfigurationsdatei außer Kraft setzt.
Alle hier vorgenommenen Einstellungen haben Vorrang.
In dieser Datei können alle vom Standard abweichenden Einstellungen übersichtlich zusammengefasst werden.
Dies hat auch den Vorteil, dass alle geänderten Einstellungen bei einer Aktualisierung des Programms beibehalten werden können.
## Konfigurationsanleitung (Beispiele)
Die hier gezeigten Konfigurationen sind nur ein Teil der Gesamtkonfiguration.
Sie dient nur dazu, die für die jeweilige Funktion notwendige und angepasste Konfiguration zu zeigen.
Alle Konfigurationen müssen in der Datei `config.cfg.owr` vorgenommen werden.
Alle möglichen Einstellungen sind in der Standard-Konfigurationsdatei `config.cfg` zu sehen.
## Admin Handbuch
Dieser Leitfaden gilt für alle Admins.
Hier werden die administrativen Möglichkeiten kurz erläutert.
## Benutzer Handbuch
Diese Anleitung gilt für Benutzer oder Administratoren.
Hier werden kurz die normalen Möglichkeiten der Software erklärt.
## FAQ
### Wie kann ich mit der Software beginnen?
Sie sollten den Abschnitt `Installationsanleitung` lesen.
Dort ist alles kurz erklärt.
Gehen Sie einfach alles von oben nach unten durch :)

View File

@ -0,0 +1,2 @@
# lxmf_bridge_telegram
Weitere Informationen finden Sie in den Konfigurationsoptionen (am Ende der Programmdateien). Alles Weitere ist dort kurz dokumentiert. Nach dem ersten Start wird diese Konfiguration als Standardkonfiguration in der entsprechenden Datei angelegt.

210
lxmf_chatbot/README_de.md Normal file
View File

@ -0,0 +1,210 @@
# lxmf_chatbot
Dieses Programm bietet einen einfachen Chatbot (RiveScript), der über LXMF kommunizieren kann.
Weitere Informationen finden Sie in den Konfigurationsoptionen (am Ende der Programmdateien).
Alles Weitere ist dort kurz dokumentiert.
Nach dem ersten Start wird diese Konfiguration als Standardkonfiguration in der entsprechenden Datei angelegt.
### Eigenschaften
- Kompatibel mit allen LXMF-Anwendungen (NomadNet, Sideband, ...)
## Beispiele für die Verwendung
###
### Allgemeine Informationen zum Transport der Nachrichten
Alle Nachrichten zwischen Client<->Server werden als einzelne 1:1 Nachrichten im LXMF/Reticulum Netzwerk transportiert.
Dementsprechend findet zwischen diesen Endpunkten eine Verschlüsselung statt.
Wenn eine direkte Zustellung der Nachricht nicht funktioniert, wird sie an einen Propagationsknoten gesendet. Dort wird sie zwischengespeichert und kann später vom Client abgerufen werden.
Da es sich um normale LXMF-Nachrichten handelt, kann jede LXMF-fähige Anwendung zur Kommunikation mit der Gruppe verwendet werden.
## Aktueller Status
Die Software befindet sich noch in der Beta-Phase und ist noch nicht fertiggestellt.
Alle Kernfunktionen sind implementiert und funktionieren, aber Ergänzungen werden wahrscheinlich auftreten, wenn die praktische Anwendung erforscht wird.
Es kann zu Fehlern kommen oder die Kompatibilität nach einem Update ist nicht mehr gewährleistet.
Die vollständige Dokumentation ist noch nicht verfügbar. Aus Zeitmangel kann ich auch nicht sagen, wann diese weiterbearbeitet werden wird.
## Screenshots / Usage examples
<img src="../docs/screenshots/lxmf_chatbot_01.png" width="200px">
## Installations Handbuch
### Installation:
- Installieren Sie alle erforderlichen Voraussetzungen.
(Standardinstallation von Reticulum. Nur erforderlich, wenn Reticulum noch nicht installiert ist).
```bash
apt update
apt upgrade
apt install python3-pip
pip install pip --upgrade
reboot
pip3 install rns
pip3 install pyserial netifaces
pip3 install lxmf
```
- Ändern Sie die Reticulum-Konfiguration entsprechend Ihren Anforderungen und Ihrem Anwendungsfall.
```bash
nano /.reticulum/config
```
- Laden Sie die [Datei](lxmf_chatbot.py) aus diesem Repository herunter.
```bash
wget https://raw.githubusercontent.com/SebastianObi/LXMF-Tools/main/lxmf_chatbot/lxmf_chatbot.py
```
- Machen Sie es mit folgendem Befehl ausführbar
```bash
chmod +x lxmf_chatbot.py
```
### Starten:
- Starten mit
```bash
./lxmf_chatbot.py
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen.
Der Speicherort der Datei wird angezeigt.
- Beispiel einer Minimalkonfiguration
(Überschreibung der Standardkonfiguration `config.cfg`).
Dies sind die wichtigsten Einstellungen, die angepasst werden müssen.
Alle anderen Einstellungen befinden sich in `config.cfg`.
```bash
nano /root/.lxmf_chatbot/config.cfg.owr
```
```bash
```
- Starten Sie erneut. Fertig!
```bash
./lxmf_chatbot.py
```
### Als Systemdienst/Dämon ausführen:
- Erstellen Sie eine Servicedatei.
```bash
nano /etc/systemd/system/lxmf_chatbot.service
```
- Kopieren Sie den folgenden Inhalt und passen Sie ihn an Ihre eigenen Bedürfnisse an.
```bash
[Unit]
Description=lxmf_chatbot.py Daemon
After=multi-user.target
[Service]
# ExecStartPre=/bin/sleep 10
Type=simple
Restart=always
RestartSec=3
User=root
ExecStart=/root/lxmf_chatbot.py
[Install]
WantedBy=multi-user.target
```
- Aktivieren Sie den Dienst.
```bash
systemctl enable lxmf_chatbot
```
- Starten Sie den Dienst.
```bash
systemctl start lxmf_chatbot
```
### Dienst starten/stoppen:
```bash
systemctl start lxmf_chatbot
systemctl stop lxmf_chatbot
```
### Aktivieren/Deaktivieren des Dienstes:
```bash
systemctl enable lxmf_chatbot
systemctl disable lxmf_chatbot
```
### Mehrere Instanzen ausführen (um dieselbe Anwendung zu kopieren):
- Führen Sie das Programm mit einem anderen Konfigurationspfad aus.
```bash
./lxmf_chatbot.py -p /root/.lxmf_chatbot_2nd
./lxmf_chatbot.py -p /root/.lxmf_chatbot_3nd
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
### Erste Verwendung:
- Bei einem manuellen Start über die Konsole wird die eigene LXMF-Adresse angezeigt:
```
[] ...............................................................................
[] LXMF - Address: <801f48d54bc71cb3e0886944832aaf8d>
[] ...............................................................................`
```
- In der Standardeinstellung wird diese Adresse auch beim Start bekannt gegeben.
- Nun kann die Software verwendet werden.
### Parameter für die Inbetriebnahme:
```bash
usage: lxmf_chatbot.py [-h] [-p PATH] [-pr PATH_RNS] [-pl PATH_LOG] [-l LOGLEVEL] [-s] [--exampleconfig] [--exampleconfigoverride]
LXMF Chatbot - Simple chatbot (RiveScript) für LXMF messages
optionale Argumente:
-h, --help diese Hilfemeldung anzeigen und beenden
-p PATH, --path PATH Pfad zum alternativen Konfigurationsverzeichnis
-pr PATH_RNS, --path_rns PATH_RNS
Pfad zum alternativen Reticulum-Konfigurationsverzeichnis
-pl PATH_LOG, --path_log PATH_LOG
Pfad zum alternativen Protokollverzeichnis
-l LOGLEVEL, --loglevel LOGLEVEL
-s, --service Läuft als Dienst und sollte sich in der Datei
--exampleconfig Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
--exampleconfigoverride
Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
```
### Configurationsdaten Dateien:
- config.cfg
Dies ist die Standardkonfigurationsdatei.
- config.cfg.owr
Dies ist die Benutzerkonfigurationsdatei, die die Standardkonfigurationsdatei außer Kraft setzt.
Alle hier vorgenommenen Einstellungen haben Vorrang.
In dieser Datei können alle vom Standard abweichenden Einstellungen übersichtlich zusammengefasst werden.
Dies hat auch den Vorteil, dass alle geänderten Einstellungen bei einer Aktualisierung des Programms beibehalten werden können.
## Konfigurationshandbuch (Beispiele)
Die hier gezeigten Konfigurationen sind nur ein Teil der Gesamtkonfiguration.
Sie dienen nur dazu, die für die jeweilige Funktion notwendige und angepasste Konfiguration zu zeigen.
Alle Konfigurationen müssen in der Datei `config.cfg.owr` vorgenommen werden.
Alle möglichen Einstellungen sind in der Standard-Konfigurationsdatei `config.cfg` zu sehen.
## Admin Handbuch
Dieser Leitfaden gilt für alle Admins. Hier werden die administrativen Möglichkeiten kurz erläutert.
## User Handbuch
Diese Anleitung gilt für Benutzer oder Administratoren. Hier werden kurz die normalen Möglichkeiten der Software erklärt.
## FAQ
### Wie kann ich mit der Software beginnen?
Sie sollten den Abschnitt `Installationsanleitung` lesen. Dort ist alles kurz erklärt. Gehen Sie einfach alles von oben nach unten durch :)

201
lxmf_cmd/README_de.md Normal file
View File

@ -0,0 +1,201 @@
# lxmf_cmd
Dieses Programm führt jeden per Nachricht empfangenen Text als Systembefehl aus und gibt die Ausgabe des Befehls als Nachricht zurück. Es können nur einzelne Befehle direkt ausgeführt werden. Es wird kein interaktives Terminal erzeugt.
Weitere Informationen finden Sie in den Konfigurationsoptionen (am Ende der Programmdateien). Alles Weitere ist dort kurz dokumentiert. Nach dem ersten Start wird diese Konfiguration als Standardkonfiguration in der entsprechenden Datei angelegt.
### Merkmale
- Kompatibel mit allen LXMF-Anwendungen (NomadNet, Sideband, ...)
## Beispiele für die Verwendung
###
### Allgemeine Informationen zum Transport der Nachrichten
Alle Nachrichten zwischen Client<->Server werden als einzelne 1:1 Nachrichten im LXMF/Reticulum Netzwerk transportiert.
Dementsprechend findet zwischen diesen Endpunkten eine Verschlüsselung statt.
Wenn eine direkte Zustellung der Nachricht nicht funktioniert, wird sie an einen Propagationsknoten gesendet. Dort wird sie zwischengespeichert und kann später vom Client abgerufen werden.
Da es sich um normale LXMF-Nachrichten handelt, kann jede LXMF-fähige Anwendung zur Kommunikation mit der Gruppe verwendet werden.
## Aktueller Status
Die Software befindet sich noch in der Beta-Phase und ist noch nicht fertiggestellt.
Alle Kernfunktionen sind implementiert und funktionieren, aber Ergänzungen werden wahrscheinlich auftreten, wenn die praktische Anwendung erforscht wird.
Es kann zu Fehlern kommen oder die Kompatibilität nach einem Update ist nicht mehr gewährleistet.
Die vollständige Dokumentation ist noch nicht verfügbar. Aus Zeitmangel kann ich auch nicht sagen, wann diese weiterbearbeitet werden wird.
## Bilder/ Beispiele für den Gebrauch
<img src="../docs/screenshots/lxmf_cmd_01.png" width="200px">
## Installations Handbuch
### Installation:
- Installieren Sie alle erforderlichen Voraussetzungen. (Standardinstallation von Reticulum. Nur erforderlich, wenn Reticulum noch nicht installiert ist).
```bash
apt update
apt upgrade
apt install python3-pip
pip install pip --upgrade
reboot
pip3 install rns
pip3 install pyserial netifaces
pip3 install lxmf
```
- Ändern Sie die Reticulum-Konfiguration entsprechend Ihren Anforderungen und Ihrem Anwendungsfall.
```bash
nano /.reticulum/config
```
- Laden Sie die [Datei](lxmf_cmd.py) aus diesem Repository herunter.
```bash
wget https://raw.githubusercontent.com/SebastianObi/LXMF-Tools/main/lxmf_cmd/lxmf_cmd.py
```
- Machen Sie es mit folgendem Befehl ausführbar
```bash
chmod +x lxmf_cmd.py
```
### Starten:
- Start mit
```bash
./lxmf_cmd.py
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
- Beispiel einer Minimalkonfiguration (Überschreibung der Standardkonfiguration `config.cfg`). Dies sind die wichtigsten Einstellungen, die angepasst werden müssen. Alle anderen Einstellungen befinden sich in `config.cfg`.
```bash
nano /root/.lxmf_cmd/config.cfg.owr
```
```bash
```
- Starten Sie erneut. Fertig!
```bash
./lxmf_cmd.py
```
### Als Systemdienst/Dämon ausführen:
- Erstellen Sie eine Servicedatei.
```bash
nano /etc/systemd/system/lxmf_cmd.service
```
- Kopieren Sie den folgenden Inhalt und passen Sie ihn an Ihre eigenen Bedürfnisse an.
```bash
[Unit]
Description=lxmf_cmd.py Daemon
After=multi-user.target
[Service]
# ExecStartPre=/bin/sleep 10
Type=simple
Restart=always
RestartSec=3
User=root
ExecStart=/root/lxmf_cmd.py
[Install]
WantedBy=multi-user.target
```
- Aktivieren Sie den Dienst.
```bash
systemctl enable lxmf_cmd
```
- Starten Sie den Dienst.
```bash
systemctl start lxmf_cmd
```
### Dienst starten/stoppen:
```bash
systemctl start lxmf_cmd
systemctl stop lxmf_cmd
```
### Dienst aktivieren/deaktivieren:
```bash
systemctl enable lxmf_cmd
systemctl disable lxmf_cmd
```
### Führen Sie mehrere Instanzen aus (Kopieren der gleichen Anwendung):
- Führen Sie das Programm mit einem anderen Konfigurationspfad aus.
```bash
./lxmf_cmd.py -p /root/.lxmf_cmd_2nd
./lxmf_cmd.py -p /root/.lxmf_cmd_3nd
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
### Erste Verwendung:
- Bei einem manuellen Start über die Konsole wird die eigene LXMF-Adresse angezeigt:
```
[] ...............................................................................
[] LXMF - Address: <801f48d54bc71cb3e0886944832aaf8d>
[] ...............................................................................`
```
- In der Standardeinstellung wird diese Adresse auch beim Start bekannt gegeben.
- Nun kann die Software verwendet werden.
### Parameter für die Inbetriebnahme:
```bash
usage: lxmf_cmd.py [-h] [-p PATH] [-pr PATH_RNS] [-pl PATH_LOG] [-l LOGLEVEL] [-s] [--exampleconfig] [--exampleconfigoverride]
LXMF CMD -
optionale Argumente:
-h, --help diese Hilfemeldung anzeigen und beenden
-p PATH, --path PATH Pfad zum alternativen Konfigurationsverzeichnis
-pr PATH_RNS, --path_rns PATH_RNS
Pfad zum alternativen Reticulum-Konfigurationsverzeichnis
-pl PATH_LOG, --path_log PATH_LOG
Pfad zum alternativen Protokollverzeichnis
-l LOGLEVEL, --loglevel LOGLEVEL
-s, --service Läuft als Dienst und sollte Loggen in die Datei
--exampleconfig Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
--exampleconfigoverride
Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
```
### Configurationsdaten Dateien:
- config.cfg
Dies ist die Standardkonfigurationsdatei.
- config.cfg.owr
Dies ist die Benutzerkonfigurationsdatei, die die Standardkonfigurationsdatei außer Kraft setzt.
Alle hier vorgenommenen Einstellungen haben Vorrang.
In dieser Datei können alle vom Standard abweichenden Einstellungen übersichtlich zusammengefasst werden.
Dies hat auch den Vorteil, dass alle geänderten Einstellungen bei einer Aktualisierung des Programms beibehalten werden können.
## Konfigurationshandbuch (Beispiele)
Die hier gezeigten Konfigurationen sind nur ein Teil der Gesamtkonfiguration.
Sie dienen nur dazu, die für die jeweilige Funktion notwendige und angepasste Konfiguration zu zeigen.
Alle Konfigurationen müssen in der Datei `config.cfg.owr` vorgenommen werden.
Alle möglichen Einstellungen sind in der Standard-Konfigurationsdatei `config.cfg` zu sehen.
## Administratoren Handbuch
Dieses Handbuch gilt für alle Admins. Hier werden die administrativen Möglichkeiten kurz erläutert.
## User Handbuch
Diese Anleitung gilt für Benutzer oder Administratoren. Hier werden kurz die normalen Möglichkeiten der Software erklärt.
## FAQ
### Wie kann ich mit der Software beginnen?
Sie sollten den Abschnitt `Installationsanleitung` lesen. Dort ist alles kurz erklärt. Gehen Sie einfach alles von oben nach unten durch :)

View File

@ -0,0 +1,755 @@
# lxmf_distribution_group
Dieses Programm bietet eine E-Mail-ähnliche Verteilergruppe. Es verteilt eingehende LXMF-Nachrichten an mehrere Empfänger. Da dieses Programm wie ein normaler LXMF-Endpunkt agiert, können alle kompatiblen Chat-Anwendungen verwendet werden. Zusätzlich zum einfachen Messaging gibt es eine einfache kommandobasierte Benutzeroberfläche. Hier können alle relevanten Aktionen für die tägliche Verwaltung durchgeführt werden. Die Grundkonfiguration wird in den Konfigurationsdateien vorgenommen. Es gibt verschiedene Optionen, um das gesamte Verhalten der Gruppe an die eigenen Bedürfnisse anzupassen. Diese Verteilergruppe ist viel mehr als eine Standard-E-Mail-Verteilergruppe. Sie emuliert erweiterte Gruppenfunktionen mit automatischen Benachrichtigungen usw. Es können verschiedene Benutzerberechtigungen definiert werden. Für jeden Benutzertyp kann der Funktionsumfang individuell festgelegt werden. Die normalen Benutzer haben nur geringe Rechte. Während ein Moderator oder Admin mit einfachen Befehlen alles Notwendige erledigen kann. Ist die Grundkonfiguration einmal erledigt, kann alles Weitere über LXMF-Nachrichten als Befehle erfolgen.
Weitere Informationen finden Sie in den Konfigurationsoptionen (am Ende der Programmdateien). Alles Weitere ist dort kurz dokumentiert. Nach dem ersten Start wird diese Konfiguration als Standardkonfiguration in der entsprechenden Datei angelegt.
### Merkmale
- Kompatibel mit allen LXMF-Anwendungen (NomadNet, Sideband, ...)
- Server-/Node-basierte Nachrichtenweiterleitung und -verarbeitung
- Direkte oder propagierte Nachrichtenzustellung (Empfangen/Senden)
- Einfache Gruppenfunktionen (wie in anderen Messenger-Apps)
- Benutzerautorisierung und Berechtigungen
- Verschiedene Benutzertypen mit unterschiedlichen Berechtigungen
- Automatischer oder manueller Gruppenbeitritt
- Textbasierte Schnittstelle zur Anzeige von erweiterten Funktionen oder Informationen
- Cluster von mehreren Gruppen (Kommunikation zwischen Gruppen mit verschiedenen Levels)
- Automatisches Aushandeln von Clustern
- Statistiken auf Cluster-, Router-, Gruppen- und Benutzerebene
- Einfache Konfiguration in lesbaren Konfigurationsdateien
- Verschiedene Admin-Befehle für die täglichen Aufgaben, die über LXMF-Nachrichten gesteuert werden
- Gruppenbeschreibung, Regeln und gepinnte Nachrichten
- Optional aktivierbarer Warteraum für neue Mitglieder vor dem Beitritt zur Gruppe
- Unterstützung mehrerer Sprachen (Englisch & Deutsch sind voreingestellt)
## Beispiele für die Verwendung
### Lokale autarke Gruppe
In einer kleinen Gruppe von Personen kann diese Gruppensoftware auf einem zentral gelegenen Knoten gehostet werden. Dies ermöglicht es den Nutzern, über diese Gruppe miteinander zu kommunizieren.
### Mehrere lokale autarke Gruppen
Auf demselben Knoten/Server können mehrere Gruppen unabhängig voneinander betrieben werden. Wie das funktioniert, wird weiter unten in der Installationsanleitung beschrieben.
### Vernetzung von Gruppen zu einem Cluster
Es ist möglich, mehrere lokal unabhängige Gruppen zu einem Cluster zu verbinden. Dadurch ist es möglich, Nachrichten von einer Gruppe zur anderen zu senden.
### Hierarchische Clustergruppen über weit verteilte Gebiete
Ein Gruppencluster kann in mehreren Ebenen gebildet werden. Entsprechend der Benennung der Ebenen kann eine Gruppe mit mehreren Namen versehen werden.
Dadurch ist es möglich, z.B. eine Nachricht an mehrere Gruppen gleichzeitig zu senden. So könnten Sie die Gruppennamen wie folgt definieren. Land/Region/Stadt".
Damit ist es möglich, alle Gruppen eines bestimmten Landes oder einer bestimmten Region zu kontaktieren.
### Allgemeine Informationen zum Transport der Nachrichten
Alle Nachrichten zwischen Client<->Gruppenserver und Gruppenserver<->Gruppenserver werden als einzelne 1:1 Nachrichten im LXMF/Reticulum Netzwerk transportiert.
Dementsprechend findet zwischen diesen Endpunkten eine Verschlüsselung statt.
Wenn eine direkte Zustellung der Nachricht nicht funktioniert, wird sie an einen Propagierungsknoten gesendet. Dort wird sie zwischengespeichert und kann später vom Client abgerufen werden.
Da es sich um normale LXMF-Nachrichten handelt, kann jede LXMF-fähige Anwendung zur Kommunikation mit der Gruppe verwendet werden.
Wenn eine Nachricht an einen mehrstufigen (hierarchischen) Cluster gesendet wird. Es wird immer eine 1:1-Verbindung von der Quelle zu jeder Zielgruppe in dieser Clusterebene hergestellt.
Es gibt keinen zentralen Server für die Kommunikation zwischen den einzelnen Gruppen. Dies bietet den Vorteil, dass alle Gruppen autonom arbeiten. Ein Ausfall einer Gruppe betrifft nur diese eine lokale Gruppe.
## Aktueller Status
Es handelt sich derzeit um eine Betasoftware, die noch in Arbeit ist.
Alle Kernfunktionen sind implementiert und funktionieren, aber Ergänzungen werden wahrscheinlich auftreten, wenn die reale Nutzung erforscht wird.
Es kann zu Fehlern kommen oder die Kompatibilität nach einem Update ist nicht mehr gewährleistet.
Die vollständige Dokumentation ist noch nicht verfügbar. Aus Zeitmangel kann ich auch nicht sagen, wann diese weiterbearbeitet werden wird.
## Entwicklungsfahrplan
- Geplant, aber noch nicht terminiert
- Propagationsknoten-Fallback
- Automatisches Erkennen von Propagationsknoten
- Propagation Node auto select
- Parameter für die Sicherung/Wiederherstellung von Konfiguration und Daten
- Parameter für die Sicherung/Wiederherstellung der Identität
- Cluster-Brücken/Wiederholer
- Unterschiedliche Nachrichtenprioritäten
- Fallback-Lösung: Master/Slave
- Zentralisierte Benutzer-/Gruppenautorisierung
- Interne Warteschlange mit Priorisierung
- Intelligenteres Senden von Nachrichten
- Befehl zur Anzeige des Sendestatus der letzten Nachricht
- Automatische Sendebestätigung
- Vollständige Dokumentation
## Bilder/ Verwendungsbeispiele
<img src="../docs/screenshots/lxmf_distribution_group_01.png" width="200px"><img src="../docs/screenshots/lxmf_distribution_group_02.png" width="200px"><img src="../docs/screenshots/lxmf_distribution_group_03.png" width="200px"><img src="../docs/screenshots/lxmf_distribution_group_04.png" width="200px"><img src="../docs/screenshots/lxmf_distribution_group_05.png" width="200px"><img src="../docs/screenshots/lxmf_distribution_group_06.png" width="200px"><img src="../docs/screenshots/lxmf_distribution_group_07.png" width="200px"><img src="../docs/screenshots/lxmf_distribution_group_08.png" width="200px">
## Installations Handbuch
### Installation:
- Installieren Sie alle erforderlichen Voraussetzungen. (Standardinstallation von Reticulum. Nur erforderlich, wenn Reticulum noch nicht installiert ist).
```bash
apt update
apt upgrade
apt install python3-pip
pip install pip --upgrade
reboot
pip3 install rns
pip3 install pyserial netifaces
pip3 install lxmf
```
- Ändern Sie die Reticulum-Konfiguration entsprechend Ihren Anforderungen und Ihrem Anwendungsfall.
```bash
nano /.reticulum/config
```
- Laden Sie die [Datei](lxmf_distribution_group.py) aus diesem Repository herunter.
```bash
wget https://raw.githubusercontent.com/SebastianObi/LXMF-Tools/main/lxmf_distribution_group/lxmf_distribution_group.py
```
- Machen Sie es mit folgendem Befehl ausführbar
```bash
chmod +x lxmf_distribution_group.py
```
### Starten:
- Start mit
```bash
./lxmf_distribution_group.py
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
- Beispiel einer Minimalkonfiguration (Überschreibung der Standardkonfiguration `config.cfg`). Dies sind die wichtigsten Einstellungen, die angepasst werden müssen. Alle anderen Einstellungen befinden sich in `config.cfg`.
```bash
nano /root/.lxmf_distribution_group/config.cfg.owr
```
```bash
# Dies ist die Benutzerkonfigurationsdatei, die die Standardkonfigurationsdatei außer Kraft setzt.
# Alle hier vorgenommenen Einstellungen haben Vorrang.
# Diese Datei kann verwendet werden, um alle Einstellungen, die vom Standard abweichen, übersichtlich zusammenzufassen.
# Dies hat auch den Vorteil, dass alle geänderten Einstellungen bei einem Update des Programms erhalten bleiben können.
#### Hauptprogrammeinstellungen ####
[main]
# Standardsprache wählen.
lng = en # en/de
#### LXMF-Verbindungseinstellungen ####
[lxmf]
# Der Name ist für andere Peers sichtbar
# im Netzwerk sichtbar und in Ankündigungen enthalten.
# Er wird auch in der Gruppenbeschreibung/Info verwendet.
display_name = Distribution Group
# Propagationsknoten Adresse/Hash.
propagation_node = ca2762fe5283873719aececfb9e18835
# Versuchen Sie, eine Nachricht über das LXMF-Verbreitungsnetz zuzustellen,
# wenn eine direkte Zustellung an den Empfänger nicht möglich ist.
try_propagation_on_fail = Yes
#### Cluster Einstellungen ####
[cluster]
# Aktivieren/Deaktivieren Sie diese Funktion.
enabled = True
# Um mehrere komplett getrennte Cluster/Gruppen zu verwenden,
# kann hier ein individueller Name und Typ vergeben werden.
name = grp
type = cluster
# Schrägstrich-getrennte Liste mit den Namen dieses Clusters.
# Diese Funktion kann verwendet werden, um mehrstufige Gruppenstrukturen aufzubauen.
# Alle Sendenachrichten, die mit dem Namen übereinstimmen (alle Ebenen), werden empfangen.
# Der letzte Name ist der Hauptname dieser Gruppe und wird als Quelle für Sendenachrichten verwendet.
# Leerzeichen sind im Namen nicht erlaubt.
display_name = County/Region/City
#### Router Einstellungen ####
[router]
# Aktivieren/Deaktivieren der Routerfunktionalität.
enabled = True
# Komma-getrennte Liste mit den Namen, für die die Nachrichten weitergeleitet/wiederholt werden sollen.
# Die Namen und Ebenen müssen mit dem verwendeten display_name des Clusters übereinstimmen.
# Es sind keine Leerzeichen im Namen erlaubt.
display_name = Country,County/Region
#### Hochverfügbarkeitseinstellungen ####
[high_availability]
# Aktivieren/Deaktivieren Sie diese Funktion.
enabled = False
# Rolle dieses Knotens (Master/Slave)
role = master
# Peer Addresse
peer =
#### Statistik/Zähler-Einstellungen ####
[statistic]
# Aktivieren/Deaktivieren Sie diese Funktion.
enabled = True
```
- Starten Sie erneut. Fetig!
```bash
./lxmf_distribution_group.py
```
### Als Systemdienst/Dämon ausführen:
- Erstellen Sie eine Servicedatei.
```bash
nano /etc/systemd/system/lxmf_distribution_group.service
```
- Kopieren Sie den folgenden Inhalt und passen Sie ihn an Ihre eigenen Bedürfnisse an.
```bash
[Unit]
Description=lxmf_distribution_group.py Daemon
After=multi-user.target
[Service]
# ExecStartPre=/bin/sleep 10
Type=simple
Restart=always
RestartSec=3
User=root
ExecStart=/root/lxmf_distribution_group.py
[Install]
WantedBy=multi-user.target
```
- Aktivieren Sie den Dienst.
```bash
systemctl enable lxmf_distribution_group
```
- Starten Sie den Dienst.
```bash
systemctl start lxmf_distribution_group
```
### Dienst starten/stoppen:
```bash
systemctl start lxmf_distribution_group
systemctl stop lxmf_distribution_group
```
### Aktivieren/Deaktivieren des Dienstes:
```bash
systemctl enable lxmf_distribution_group
systemctl disable lxmf_distribution_group
```
### Mehrere Instanzen ausführen (um dieselbe Anwendung zu kopieren):
- Führen Sie das Programm mit einem anderen Konfigurationspfad aus.
```bash
./lxmf_distribution_group.py -p /root/.lxmf_distribution_group_2nd
./lxmf_distribution_group.py -p /root/.lxmf_distribution_group_3nd
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
### Erste Verwendung:
- Bei einem manuellen Start über die Konsole wird die eigene Gruppen-LXMF-Adresse angezeigt:
```
[] ...............................................................................
[] LXMF - Address: <801f48d54bc71cb3e0886944832aaf8d>
[] ...............................................................................`
```
- In der Standardeinstellung wird diese Adresse auch beim Start bekannt gegeben.
- Wenn auto add user aktiv ist (Standardeinstellung), können Sie einfach eine erste Nachricht über Sideband/NomadNet an diese Adresse senden. Danach sind Sie Mitglied der Gruppe und können die Funktionen nutzen.
- Alternativ können die Benutzer auch manuell in der Datei `data.cfg` eingetragen werden. Es ist notwendig, hier einen Admin-Benutzer hinzuzufügen, um alle Befehle über LXMF-Nachrichten nutzen zu können!
- Nun kann die Gruppe benutzt werden.
### Parameter für die Inbetriebnahme:
```bash
usage: lxmf_distribution_group.py [-h] [-p PATH] [-pr PATH_RNS] [-pl PATH_LOG] [-l LOGLEVEL] [-s] [--exampleconfig] [--exampleconfigoverride] [--exampledata]
LXMF Distribution Group - Server-seitige Gruppenfunktionen für LXMF-basierte Anwendungen
optionale Argumente:
-h, --help diese Hilfemeldung anzeigen und beenden
-p PATH, --path PATH Pfad zum alternativen Konfigurationsverzeichnis
-pr PATH_RNS, --path_rns PATH_RNS
Pfad zum alternativen Reticulum-Konfigurationsverzeichnis
-pl PATH_LOG, --path_log PATH_LOG
Pfad zum alternativen Protokollverzeichnis
-l LOGLEVEL, --loglevel LOGLEVEL
-s, --service Läuft als Dienst und sollte sich in der Datei
--exampleconfig Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
--exampleconfigoverride
Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
--exampledata Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
```
### Configurationsdaten Dateien:
- config.cfg
Dies ist die Standardkonfigurationsdatei.
- config.cfg.owr
Dies ist die Benutzerkonfigurationsdatei, die die Standardkonfigurationsdatei außer Kraft setzt.
Alle hier vorgenommenen Einstellungen haben Vorrang.
In dieser Datei können alle vom Standard abweichenden Einstellungen übersichtlich zusammengefasst werden.
Dies hat auch den Vorteil, dass alle geänderten Einstellungen bei einer Aktualisierung des Programms beibehalten werden können.
- data.cfg
Dies ist die Datendatei. Sie wird automatisch erstellt und gespeichert/überschrieben.
Sie enthält Daten, die von der Software selbst verwaltet werden.
Wenn hier manuelle Anpassungen vorgenommen werden, muss das Programm vorher beendet werden!
## Konfigurationshandbuch (Beispiele)
Die hier gezeigten Konfigurationen sind nur ein Teil der Gesamtkonfiguration.
Sie dienen nur dazu, die für die jeweilige Funktion notwendige und angepasste Konfiguration zu zeigen.
Alle Konfigurationen müssen in der Datei `config.cfg.owr` vorgenommen werden.
Alle möglichen Einstellungen sind in der Standard-Konfigurationsdatei `config.cfg` zu sehen.
### Cluster:
Dieses Beispiel zeigt die Konfiguration für einen Cluster mit 2 Gruppen. Dies ermöglicht die Kommunikation zwischen beiden Gruppen.
Es ist möglich, direkt in jede Gruppe zu schreiben oder in die übergeordnete Ebene, die dann beide Gruppen umfasst.
- Group #1 `config.cfg.owr`
```
[lxmf]
display_name = Group Test 1
[cluster]
enabled = True
name = test
type = cluster
display_name = Germany/NRW/Düsseldorf
```
- Group #1 `data.cfg`
```
[main]
enabled_cluster = True
auto_add_cluster = True
```
- Group #2 `config.cfg.owr`
```
[lxmf]
display_name = Group Test 2
[cluster]
enabled = True
name = test
type = cluster
display_name = Germany/Bayern/München
```
- Group #2 `data.cfg`
```
[main]
enabled_cluster = True
auto_add_cluster = True
```
### 2 unabhängige Cluster:
Dieses Beispiel zeigt die Konfiguration für 2 separate Cluster.
Damit ist es möglich, mehrere Cluster parallel über das gleiche Kommunikationsnetz zu betreiben.
Es ist wichtig, `Name` und `Typ` unterschiedlich zu konfigurieren.
- Cluster #1 - Group #1 `config.cfg.owr`
```
[lxmf]
display_name = Group Test 1
[cluster]
enabled = True
name = test1
type = cluster
display_name = Germany/NRW/Düsseldorf
```
- Cluster #1 - Group #1 `data.cfg`
```
[main]
enabled_cluster = True
auto_add_cluster = True
```
- Cluster #2 - Group #1 `config.cfg.owr`
```
[lxmf]
display_name = Group Test 1
[cluster]
enabled = True
name = test2
type = cluster
display_name = Germany/NRW/Düsseldorf
```
- Cluster #2 - Group #1 `data.cfg`
```
[main]
enabled_cluster = True
auto_add_cluster = True
```
### Mitglieder/Cluster:
Normalerweise werden alle Daten hier (`data.cfg`) automatisch von der Software erstellt. Basierend auf der automatischen Erstellung von neuen Benutzern/Clustern oder ausgeführten Befehlen zur Verwaltung.
Hier sind ein paar Beispiele, wie der Inhalt aussehen kann. Natürlich kann die Datei auch manuell bearbeitet werden. Dies ist notwendig, wenn ein automatisches Hinzufügen deaktiviert ist.
Bitte vergessen Sie nicht, das Programm vorher zu schließen!
- Group #1 `data.cfg`
```
[user]
04652a820cc69d47940ce39050c455a6 = Test User 1
[cluster]
d1b551e1b89fff5a4a6f2aaff2464971 = Germany/Bayern/München
```
- Group #2 `data.cfg`
```
[user]
18201a931dd69d47940ce39050c487c9 = Test User 1
[cluster]
801f48d54bc71cb3e0886944832aaf8d = Germany/NRW/Düsseldorf
```
### Cluster router:
Noch nicht umgesetzt
### Ankündigung der Gruppe:
- `config.cfg.owr`
```
[lxmf]
announce_startup = Yes
announce_startup_delay = 0 #Seconds
announce_periodic = Yes
announce_periodic_interval = 120 #Minutes
```
### Message propagation - Senden:
- `config.cfg.owr`
```
[lxmf]
desired_method = direct #direct/propagated
propagation_node = ca2762fe5283873719aececfb9e18835
try_propagation_on_fail = Yes
```
### Message propagation - Empfang(Sync vom Knoten):
- `config.cfg.owr`
```
[lxmf]
propagation_node = ca2762fe5283873719aececfb9e18835
sync_startup = Yes
sync_startup_delay = 30 #Seconds
sync_periodic = Yes
sync_periodic_interval = 30 #Minutes
sync_limit = 8
```
### Warteraum für neue Mitglieder:
Dieses Beispiel zeigt die Konfiguration für einen Warteraum für neue Mitglieder.
Wenn ein unbekannter Benutzer der Gruppe durch die erste Nachricht an die Gruppe beitritt, wird er zum Typ "Warten" hinzugefügt.
Dort befindet er sich dann in einer Art Warteraum, in dem keine Nachrichten geschrieben und empfangen werden können.
Ein Admin oder Moderator kann dann diesen Benutzer zulassen oder verbieten.
Die Konfiguration zeigt nur den minimal notwendigen Teil für diese Funktionalität. Natürlich können den Benutzern weitere Rechte zugewiesen werden.
- `config.cfg.owr`
```
[rights]
admin = interface,receive_join,allow,deny
mod = interface,receive_join,allow,deny
wait =
[interface_messages]
auto_add_wait = Welcome to the group "!display_name!"!!n!!n!You still need to be allowed to join. You will be notified automatically.
auto_add_wait-de = Willkommen in der Gruppe "!display_name!"!!n!!n!Der Beitritt muss ihnen noch erlaubt werden. Sie werden darüber automatisch benachrichtigt.
allow_user = You have been allowed to join the group "!display_name!"!!n!!n!!description!!n!!n!The messages sent here are distributed to all group members.!n!!n!For help enter /?!n!!n!To read the group rules use the command /rules!n!!n!Please assign a nickname with the command /name
allow_user-de = Sie wurden erlaubt der Gruppe "!display_name!" beizutreten!!n!!n!!description!!n!!n!Die hier gesendeten Nachrichten werden an alle Gruppenmitglieder verteilt.!n!!n!Für Hilfe geben Sie /? ein.!n!!n!Um die Gruppenregeln zu lesen verwenden Sie den Befehl /rules!n!!n!Bitte vergeben Sie einen Nickname mit dem Befehl /name
deny_user = You have been denied to join the group "!display_name!"!
deny_user-de = Ihnen wurde der Beitritt in die Gruppe "!display_name!" abgelehnt!
member_join = !source_name! <!source_address!> joins the waiting room and must be allowed to join the group.
member_join-de = !source_name! <!source_address!> betritt den Warteraum und muss zur Gruppe zugelassen werden.
```
- `data.cfg`
```
[main]
auto_add_user = True
auto_add_user_type = wait
allow_user = True
allow_user_type = user
deny_user = True
deny_user_type = block_wait
```
## Administratoren Handbuch
Dieses Handbuch gilt für alle Admins. Hier werden die administrativen Möglichkeiten kurz erläutert.
Ein Administartor hat entsprechend höhere Rechte und es stehen mehr Befehle zur Verfügung. Generell können die Berechtigungen frei definiert werden. Alle Benutzer/Admins etc. können auch generell die gleichen Berechtigungen haben.
### Aktivieren/Deaktivieren von Funktionen:
Die folgenden Funktionen können per Befehl entsprechend eingestellt werden.
`/enable_local <true/false>` = Lokales Nachrichten Routing
`/enable_cluster <true/false>` = Cluster Nachrichten Routing
`/auto_add_user <true/false>` = Funktionalität für unbekannte Benutzer hinzufügen
`/auto_add_cluster <true/false>` = Funktionalität für unbekannte Cluster hinzufügen
### Werte ändern:
`/description <description>` = Beschreibung ändern
`/rules <description>` = Regeln ändern
### Senden Sie eine manuelle Ankündigung der Gruppe und des Clusters:
`/announce`
### Benutzer verwalten (Anzeige der vorhandenen Benutzer):
`/show or /list`
`/show or /list <admin/mod/user/guest>`
`/search <nickname/user_address>`
### Verwalten von Benutzern (einladen):
Zusätzliche Benutzer können eingeladen werden, dies geschieht mit dem Befehl `/invite <Benutzer_Adresse>`.
Dann erhält der Benutzer eine Willkommensnachricht und tritt der Gruppe bei.
### Benutzer verwalten (zulassen/verweigern):
Wenn das Wartezimmer aktiviert ist, können die Benutzer mit den folgenden 2 Befehlen verwaltet werden.
`/allow <user_address>`
`/deny <user_address>`
### Verwalten von Benutzern (hinzufügen/löschen/verschieben):
Die folgenden Befehle können zur Verwaltung der Benutzer verwendet werden.
Nur im Falle einer Einladung wird eine Willkommensnachricht an den Benutzer gesendet. Benutzer, die hier hinzugefügt werden, erhalten keine Benachrichtigung und müssen die erste Konversation mit der Gruppe selbst beginnen. Oder sie bekommen direkt eine Nachricht zugesandt.
`/add <admin/mod/user/guest> <user_address> <user_name>`
`/del or /rm <admin/mod/user/guest> <user_address>`
`/del or /rm <user_address>`
`/move <admin/mod/user/guest> <user_address>`
### Benutzer verwalten (kick/block/unblock):
Mit den folgenden Befehlen können Sie Benutzer entfernen/aktivieren.
`/kick <user_address>`
`/block <user_address>`
`/unblock <user_address>`
### Daten speichern:
Wenn in der Konfiguration ein automatisches Speichern eingestellt ist, muss hier nichts gemacht werden. Falls nicht oder zusätzlich können die Daten mit dem folgenden Befehl gespeichert werden.
`/save`
### Hilfe:
Um die Hilfe und alle verfügbaren Befehle anzuzeigen, können die folgenden Befehle verwendet werden. `/help` oder `/?`
### Beispiele für mögliche Befehle:
```
/help or /? = Zeigt diese Hilfe an
/leave or /part = Gruppe verlassen
/name = Aktuellen Nickname anzeigen
/nick = Aktuellen Nickname anzeigen
/name <your nickname> = Spitznamen ändern/festlegen
/nick <your nickname> = Spitznamen ändern/festlegen
/address = Adressdaten anzeigen
/info = Gruppeninfo anzeigen
/description = Aktuelle Beschreibung anzeigen
/rules = Aktuelle Regeln anzeigen
/version = Versionsinformationen anzeigen
/groups or /cluster = Alle Gruppen/Cluster anzeigen
/groups <name> = Suche nach einer Gruppe/einem Cluster anhand des Namens
/members or /names or /who = Alle Gruppenmitglieder zeigen
/admins = Gruppenadmins anzeigen
/moderators or /mods = Gruppenmoderatoren anzeigen
/users = Gruppenbenutzer anzeigen
/guests = Gruppengäste anzeigen
/search <nickname/user_address> = Sucht nach einem Benutzer anhand seines Spitznamens oder seiner Adresse
/whois <nickname/user_address> = Sucht nach einem Benutzer anhand seines Spitznamens oder seiner Adresse
/activitys = Benutzeraktivitäten anzeigen
/statistic or /stat = Gruppenstatistik anzeigen
/status = Status anzeigen
/delivery or /message = Zustellungsstatus der letzten Nachricht anzeigen
/enable_local <true/false> = Lokales Nachrichten Routing an/ausschalten
/enable_cluster <true/false> = Weiterleitung von Cluster Nachrichten an/ausschalten
/auto_add_user <true/false> = Funktionalität für unbekannte Benutzer an/ausschalten
/auto_add_user_type <admin/mod/user/guest>
/auto_add_cluster <true/false> = Unbekannte Cluster-Funktionalität hinzufügen
/invite_user <true/false> = Einladungsfunktion
/invite_user_type <admin/mod/user/guest>
/description <description> = Beschreibung ändern
/rules <description> = Regeln ändern
/announce = Ankündigung senden
/sync = Nachrichten mit dem Verbreitungsknoten synchronisieren
/show run = Aktuelle Konfiguration anzeigen
/show or /list
/show or /list <admin/mod/user/guest>
/add <admin/mod/user/guest> <user_address> <user_name>
/del or /rm <admin/mod/user/guest> <user_address>
/del or /rm <user_address>
/move <admin/mod/user/guest> <user_address>
/invite <user_address> = Lädt Benutzer zur Gruppe ein
/kick <user_address> = Schmeißt den Benutzer aus der Gruppe
/block <user_address> = Benutzer sperren
/ban <user_address> = Benutzer sperren
/unblock <user_address> = Benutzer entsperren
/unban <user_address> = Benutzer entsperren
/load or /read = Lesen der Konfiguration/Daten
/save or /wr = Speichert die aktuelle Konfiguration/Daten
```
## User Handbuch
Diese Anleitung gilt für Benutzer oder Administratoren. Hier werden kurz die normalen Möglichkeiten der Software erklärt.
### Starten Sie die Gruppe und treten Sie ihr bei:
Senden Sie einfach eine erste Nachricht an die Gruppenadresse mit Sideband/NomadNet.
Dies ist jedoch nur möglich, wenn der automatische Beitritt zur Gruppe aktiviert ist.
### Lokale Gruppennachricht senden:
Jeder normale Text ohne `/` oder `@` am Anfang wird als normale Nachricht interpretiert und entsprechend an alle lokalen Mitglieder gesendet. Es gibt hier nichts weiter zu beachten.
### Clusternachricht senden:
Es ist möglich, Nachrichten an andere Gruppen zu senden, die Teil des Clusters sind. Dazu müssen Sie zuerst den Befehl `@` gefolgt vom Zielnamen der Gruppe und dann den normalen Nachrichtentext eingeben.
Zum Beispiel `@Berlin Hallo dies ist ein Test :)`. Dieses Beispiel würde also diese Nachricht an die Gruppe Berlin senden.
Eine Gruppe in einem Cluster kann hierarchisch in verschiedenen Ebenen angeordnet sein. Wenn die übergeordnete Ebene als Ziel definiert ist, erhalten alle darunter liegenden Gruppen diese Nachricht.
Zum Beispiel gibt es die folgenden 3 Gruppen `Deutschland/Berlin` und `Deutschland/Hamburg` und `Deutschland/München`. Entsprechend können diese direkt oder eine höhere Ebene angeschrieben werden.
Mit dem Befehl `@Germany` sind nun alle 3 Gruppen erreichbar. Mit dem Befehl `@München` ist nur diese eine Gruppe zugänglich.
### Nachricht anheften (lokale Gruppe):
Es ist möglich, Nachrichten der lokalen Gruppe dauerhaft anzuheften. Diese wird dann an alle Mitglieder gesendet. Außerdem können alle angehefteten Nachrichten später angezeigt werden.
Diese Funktion ist nützlich, um neuen Mitgliedern Zugang zu wichtigen Nachrichten aus der Vergangenheit zu geben.
/pin" = Alle angehefteten Nachrichten anzeigen
/pin <Nachrichtentext>` = Eine neue Nachricht anheften
`/unpin <#id>` = Eine angeheftete Nachricht entfernen
### Nachricht anheften (Clustergruppe):
Es ist möglich, Nachrichten der Clustergruppe dauerhaft zu pinnen. Diese wird dann an alle Mitglieder gesendet. Außerdem können alle gepinnten Nachrichten später angezeigt werden.
Diese Funktion ist nützlich, um neuen Mitgliedern Zugang zu wichtigen Nachrichten aus der Vergangenheit zu geben.
`@Group /pin <Nachrichtentext>` = Eine neue Nachricht anheften
### Schnittstelle/Befehle:
Eine einfache textnachrichtenbasierte Benutzeroberfläche ist integriert. Wie Sie es vielleicht von anderen Chat-Programmen kennen. Jeder Befehl muss mit dem Begrenzungszeichen `/` beginnen. Dann folgen der Befehl und eventuelle Daten. Zum Beispiel `/name Mein neuer Nickname`.
Wenn kein `/` am Anfang steht, ist dies eine normale Nachricht und wird an die anderen Mitglieder gesendet.
### Hilfe:
Um die Hilfe und alle verfügbaren Befehle anzuzeigen, können die folgenden Befehle verwendet werden. `/help` oder `/?`
### Die Gruppe verlassen:
Der Befehl `/leave` wird verwendet, um die Gruppe zu verlassen. Danach kann die Gruppe wieder betreten werden (wenn dies erlaubt ist).
### Benutzer einladen:
Wenn der Administrator erlaubt hat, dass weitere Benutzer eingeladen werden, kann dies mit dem Befehl `/invite <Benutzer_Adresse>` geschehen.
Dann erhält der Benutzer eine Willkommensnachricht und tritt der Gruppe bei.
### Nickname ändern:
Der eigene Nickname wird entweder automatisch über die empfangene Ankündigung (nach dem Beitritt zur Gruppe) vergeben oder kann über den folgenden Befehl geändert werden.
`/name <Ihr neuer Nickname>` Zum Beispiel `/name Max Walker`.
### Beispiele für mögliche Befehle:
```
/help or /? = Zeigt diese Hilfe
/leave or /part = Gruppe verlassen
/name = Aktuellen Namen anzeigen
/nick = Aktuellen Namen anzeigen
/name <your nickname> = Name ändern/festlegen
/nick <your nickname> = Name ändern/festlegen
/address = Adressinformationen anzeigen
/info = Gruppeninformationen anzeigen
/description = Aktuelle Beschreibung anzeigen
/rules = Aktuelle Regeln anzeigen
/version = Versionsinformationen anzeigen
/groups or /cluster = Alle Gruppen/Cluster anzeigen
/groups <name> = Suche nach einer Gruppe/einem Cluster anhand des Namens
/members or /names or /who = Alle Gruppenmitglieder anzeigen
/admins = Gruppenadministratoren anzeigen
/moderators or /mods = Gruppenmoderatoren anzeigen
/users = Gruppenbenutzer anzeigen
/guests = Gruppengäste anzeigen
/search <nickname/user_address> = Sucht nach einem Benutzer anhand seines Namens oder seiner Adresse
/whois <nickname/user_address> = Sucht nach einem Benutzer anhand seines Namens oder seiner Adresse
/activitys = Benutzeraktivitäten anzeigen
/statistic or /stat = Gruppenstatistik anzeigen
/delivery or /message = Zustellungsstatus der letzten Nachricht anzeigen
/invite <user_address> = Lädt Benutzer zur Gruppe ein
```
## FAQ
### Warum diese serverbasierte Gruppenfunktion und keine direkten Gruppen in der Client-Software?
Zum Zeitpunkt der Entwicklung dieser Gruppenfunktionen gab es keine andere Möglichkeit, Gruppen über Sideband/Nomadnet zu verwenden. Daher wurde diese Software als Workaround entwickelt.
Diese Software bietet auch andere Funktionen als eine normale Gruppenübertragung.
### Wie kann ich mit der Software beginnen?
Sie sollten den Abschnitt `Installationsanleitung` lesen. Dort ist alles kurz erklärt. Gehen Sie einfach alles von oben nach unten durch :)

View File

@ -0,0 +1,301 @@
# lxmf_distribution_group_minimal
Dieses Programm ist eine minimalistische Version der normalen Verteilungsgruppe. Die Funktionalität ist auf ein Minimum reduziert. Es können nur Absender und Empfänger definiert werden. Die Nachrichten werden dann entsprechend an die anderen Benutzer gesendet. Es gibt keine Benutzeroberfläche oder sonstige Benachrichtigungen. Lediglich die Nachrichten werden 1:1 verteilt. Die Verwaltung erfolgt komplett über die jeweiligen Konfigurationsdateien, die entsprechend zu bearbeiten sind.
Weitere Informationen finden Sie in den Konfigurationsoptionen (am Ende der Programmdateien). Alles Weitere ist dort kurz dokumentiert. Nach dem ersten Start wird diese Konfiguration als Standardkonfiguration in der entsprechenden Datei angelegt.
### Merkmale
- Kompatibel mit allen LXMF-Anwendungen (NomadNet, Sideband, ...)
- Server-/Node-basierte Nachrichtenweiterleitung und -verarbeitung
- Direkte oder propagierte Nachrichtenzustellung (Empfang/Sendung)
- Einfache Verteilung von eingehenden Nachrichten an Empfänger
## Beispiele für die Verwendung
### Lokale autarke Gruppe
In einer kleinen Gruppe von Personen kann diese Gruppensoftware auf einem zentral gelegenen Knoten gehostet werden. Dies ermöglicht es den Nutzern, über diese Gruppe miteinander zu kommunizieren.
### Mehrere lokale autarke Gruppen
Auf demselben Knoten/Server können mehrere Gruppen unabhängig voneinander betrieben werden. Wie das funktioniert, wird weiter unten in der Installationsanleitung beschrieben.
### Allgemeine Informationen zum Transport der Nachrichten
Alle Nachrichten zwischen Client<->Gruppenserver werden als einzelne 1:1 Nachrichten im LXMF/Reticulum Netzwerk transportiert.
Dementsprechend findet zwischen diesen Endpunkten eine Verschlüsselung statt.
Wenn eine direkte Zustellung der Nachricht nicht funktioniert, wird sie an einen Propagationsknoten gesendet. Dort wird sie zwischengespeichert und kann später vom Client abgerufen werden.
Da es sich um normale LXMF-Nachrichten handelt, kann jede LXMF-fähige Anwendung zur Kommunikation mit der Gruppe verwendet werden.
## Aktueller Status
Es handelt sich derzeit um eine Betasoftware, die noch in Arbeit ist.
Alle Kernfunktionen sind implementiert und funktionieren, aber Ergänzungen werden wahrscheinlich auftreten, wenn die reale Nutzung erforscht wird.
Es kann zu Fehlern kommen oder die Kompatibilität nach einem Update ist nicht mehr gewährleistet.
Die vollständige Dokumentation ist noch nicht verfügbar. Aus Zeitmangel kann ich auch nicht sagen, wann diese weiterbearbeitet werden wird.
## Bilder / Beispiele für den Gebrauch
<img src="../docs/screenshots/lxmf_distribution_group_minimal_01.png" width="200px"><img src="../docs/screenshots/lxmf_distribution_group_minimal_02.png" width="200px"><img src="../docs/screenshots/lxmf_distribution_group_minimal_03.png" width="200px">
## Installations Handbuch
### Installation:
- Installieren Sie alle erforderlichen Voraussetzungen.
(Standardinstallation von Reticulum. Nur erforderlich, wenn Reticulum noch nicht installiert ist).
```bash
apt update
apt upgrade
apt install python3-pip
pip install pip --upgrade
reboot
pip3 install rns
pip3 install pyserial netifaces
pip3 install lxmf
```
- Ändern Sie die Reticulum-Konfiguration entsprechend Ihren Anforderungen und Ihrem Anwendungsfall.
```bash
nano /.reticulum/config
```
- Laden Sie die [Datei](lxmf_distribution_group_minimal.py) aus diesem Repository herunter.
```bash
wget https://raw.githubusercontent.com/SebastianObi/LXMF-Tools/main/lxmf_distribution_group_minimal/lxmf_distribution_group_minimal.py
```
- Machen Sie es mit folgendem Befehl ausführbar
```bash
chmod +x lxmf_distribution_group_minimal.py
```
### Starten:
- Starten mit
```bash
./lxmf_distribution_group_minimal.py
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
- Beispiel einer Minimalkonfiguration (Überschreibung der Standardkonfiguration `config.cfg`). Dies sind die wichtigsten Einstellungen, die angepasst werden müssen. Alle anderen Einstellungen befinden sich in `config.cfg`.
```bash
nano /root/.lxmf_distribution_group_minimal/config.cfg.owr
```
```bash
# Dies ist die Benutzerkonfigurationsdatei, die die Standardkonfigurationsdatei außer Kraft setzt.
# Alle hier vorgenommenen Einstellungen haben Vorrang.
# Diese Datei kann verwendet werden, um alle Einstellungen, die vom Standard abweichen, übersichtlich zusammenzufassen.
# Dies hat auch den Vorteil, dass alle geänderten Einstellungen bei einem Update des Programms erhalten bleiben können.
#### LXMF Verbindungs Einstellungen ####
[lxmf]
# Der Name ist für andere Peers sichtbar
# im Netzwerk sichtbar und in Ankündigungen enthalten.
# Er wird auch in der Gruppenbeschreibung/Info verwendet.
display_name = Distribution Group
# Adresse des Propagationsknotens/Hash.
propagation_node = ca2762fe5283873719aececfb9e18835
# Versuchen Sie, eine Nachricht über das LXMF-Verbreitungsnetz zuzustellen,
# wenn eine direkte Zustellung an den Empfänger nicht möglich ist.
try_propagation_on_fail = Yes
```
- Starten Sie erneut. Fertig!
```bash
./lxmf_distribution_group_minimal.py
```
### Als Systemdienst/Dämon ausführen:
- Erstellen einer Servicedatei.
```bash
nano /etc/systemd/system/lxmf_distribution_group_minimal.service
```
- Kopieren Sie den folgenden Inhalt und passen Sie ihn an Ihre eigenen Bedürfnisse an.
```bash
[Unit]
Description=lxmf_distribution_group_minimal.py Daemon
After=multi-user.target
[Service]
# ExecStartPre=/bin/sleep 10
Type=simple
Restart=always
RestartSec=3
User=root
ExecStart=/root/lxmf_distribution_group_minimal.py
[Install]
WantedBy=multi-user.target
```
- Aktivieren Sie den Dienst.
```bash
systemctl enable lxmf_distribution_group_minimal
```
- Starten Sie den Dienst.
```bash
systemctl start lxmf_distribution_group_minimal
```
### Dienst starten/stoppen:
```bash
systemctl start lxmf_distribution_group_minimal
systemctl stop lxmf_distribution_group_minimal
```
### Dienst aktivieren/deaktivieren:
```bash
systemctl enable lxmf_distribution_group_minimal
systemctl disable lxmf_distribution_group_minimal
```
### Führen Sie mehrere Instanzen aus (Kopieren der gleichen Anwendung):
- Führen Sie das Programm mit einem anderen Konfigurationspfad aus.
```bash
./lxmf_distribution_group_minimal.py -p /root/.lxmf_distribution_group_minimal_2nd
./lxmf_distribution_group_minimal.py -p /root/.lxmf_distribution_group_minimal_3nd
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
### Erste Verwendung:
- Bei einem manuellen Start über die Konsole wird die eigene Gruppen-LXMF-Adresse angezeigt:
```
[] ...............................................................................
[] LXMF - Address: <801f48d54bc71cb3e0886944832aaf8d>
[] ...............................................................................`
```
- Diese Adresse wird in der Standardeinstellung auch beim Start bekannt gegeben.
- Die Benutzer müssen manuell in der Datei `data.cfg` eingetragen werden.
- Nun kann die Gruppe verwendet werden.
### Parameter für die Inbetriebnahme:
```bash
usage: lxmf_distribution_group_minimal.py [-h] [-p PATH] [-pr PATH_RNS] [-pl PATH_LOG] [-l LOGLEVEL] [-s] [--exampleconfig] [--exampleconfigoverride] [--exampledata]
LXMF Distribution Group - Server-seitige Gruppenfunktionen für LXMF-basierte Anwendungen
optionale Argumente:
-h, --help Hilfemeldung anzeigen und beenden
-p PATH, --path PATH Pfad zum alternativen Konfigurationsverzeichnis
-pr PATH_RNS, --path_rns PATH_RNS
Pfad zum alternativen Reticulum-Konfigurationsverzeichnis
-pl PATH_LOG, --path_log PATH_LOG
Pfad zum alternativen Protokollverzeichnis
-l LOGLEVEL, --loglevel LOGLEVEL
-s, --service Läuft als Dienst und sollte sich in der Datei
--exampleconfig Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
--exampleconfigoverride
Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
--exampledata Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
```
### Configurationsdaten Dateien:
- config.cfg
Dies ist die Standard-Konfigurationsdatei.
- config.cfg.owr
Dies ist die Benutzerkonfigurationsdatei, die die Standardkonfigurationsdatei außer Kraft setzt.
Alle hier vorgenommenen Einstellungen haben Vorrang.
In dieser Datei können alle vom Standard abweichenden Einstellungen übersichtlich zusammengefasst werden.
Dies hat auch den Vorteil, dass alle geänderten Einstellungen bei einer Aktualisierung des Programms beibehalten werden können.
- data.cfg
Dies ist die Datendatei.
Sie enthält die Benutzerdaten.
## Konfigurationshandbuch (Beispiele)
Die hier gezeigten Konfigurationen sind nur ein Teil der Gesamtkonfiguration.
Sie dienen nur dazu, die für die jeweilige Funktion notwendige und angepasste Konfiguration zu zeigen.
Alle Konfigurationen müssen in der Datei `config.cfg.owr` vorgenommen werden.
Alle möglichen Einstellungen sind in der Standard-Konfigurationsdatei `config.cfg` zu sehen.
### Mitglieder:
Alle Daten hier (`data.cfg`) enthalten die Endbenutzer. Die Benutzer müssen manuell gepflegt werden. Es erfolgt kein automatischer Beitritt zur Gruppe.
Bitte vergessen Sie nicht, das Programm nach einer Änderung neu zu starten!
- Nur Empfangs- und nur Sendemitglieder `data.cfg`
```
[send]
04652a820cc69d47940ce39050c455a6 = Testbenutzer mit Nur-Sende-Recht 1
[receive]
d1b551e1b89fff5a4a6f2aaff2464971 = Testbenutzer mit Nur-Empfangs-Recht 1
801f48d54bc71cb3e0886944832aaf8d = Testbenutzer mit Nur-Empfangs-Recht 2
[receive_send]
```
- Empfangen und Senden von Mitgliedern (Jeder kann mit jedem kommunizieren)`data.cfg`
```
[send]
[receive]
[receive_send]
04652a820cc69d47940ce39050c455a6 = Testbenutzer 1
d1b551e1b89fff5a4a6f2aaff2464971 = Testbenutzer 2
801f48d54bc71cb3e0886944832aaf8d = Testbenutzer 3
```
## Admin Handbuch
Dieser Leitfaden gilt für alle Admins. Hier werden die administrativen Möglichkeiten kurz erläutert.
### Verwalten von Benutzern:
Alle Benutzer werden direkt in der Datei `data.cfg` verwaltet.
Es erfolgt kein automatischer Beitritt zur Gruppe.
Bitte vergessen Sie nicht, das Programm nach einer Änderung neu zu starten!
```
# Dies ist die Datendatei. Sie wird automatisch erstellt und gespeichert/überschrieben.
# Sie enthält Daten, die von der Software selbst verwaltet werden.
# Wenn hier manuelle Anpassungen vorgenommen werden, muss das Programm vorher beendet werden!
#### Benutzer mit Nur-Sende-Rechten ####
[send]
04652a820cc69d47940ce39050c455a6 = Testbenutzer 1
#### Benutzer mit nur Empfangsrechten ####
[receive]
d1b551e1b89fff5a4a6f2aaff2464971 = Testbenutzer 2
#### Benutzer mit Empfangs- und Senderechten ####
[receive_send]
801f48d54bc71cb3e0886944832aaf8d = Testbenutzer 3
```
## User Handbuch
Diese Anleitung gilt für Benutzer oder Administratoren. Hier werden kurz die normalen Möglichkeiten der Software erklärt.
### Starten/Beitreten der Gruppe:
Der Administrator muss neue Benutzer manuell anlegen.
### Nachricht senden:
Jeder Text wird als normale Nachricht interpretiert und entsprechend an alle Mitglieder gesendet. Es gibt hier nichts weiter zu beachten.
## FAQ
### Warum diese serverbasierte Gruppenfunktion und keine direkten Gruppen in der Client-Software?
Zum Zeitpunkt der Entwicklung dieser Gruppenfunktionen gab es keine andere Möglichkeit, Gruppen über Sideband/Nomadnet zu nutzen. Daher wurde diese Software als Workaround entwickelt.
Diese Software bietet auch andere Funktionen als eine normale Gruppenübertragung.
### Wie beginne ich mit der Software?
Sie sollten den Abschnitt `Installationsanleitung` lesen. Dort ist alles kurz erklärt. Gehen Sie einfach alles von oben nach unten durch :)

202
lxmf_echo/README_de.md Normal file
View File

@ -0,0 +1,202 @@
# lxmf_echo
Dieses Programm ist ein einfacher Echo-Server. Alle empfangenen Nachrichten werden 1:1 als Antwort zurückgeschickt. Es kann als einfaches Gegenstück verwendet werden, um die Chat-Funktionalität von Anwendungen zu testen.
Für weitere Informationen siehe die Konfigurationsoptionen (am Ende der Programmdateien). Alles Weitere ist dort kurz dokumentiert. Nach dem ersten Start wird diese Konfiguration als Standardkonfiguration in der entsprechenden Datei angelegt.
### Merkmale
- Kompatibel mit allen LXMF-Anwendungen (NomadNet, Sideband, ...)
## Beispiele für die Verwendung
###
### Allgemeine Informationen zum Transport der Nachrichten
Alle Nachrichten zwischen Client<->Server werden als einzelne 1:1 Nachrichten im LXMF/Reticulum Netzwerk transportiert.
Dementsprechend findet zwischen diesen Endpunkten eine Verschlüsselung statt.
Wenn eine direkte Zustellung der Nachricht nicht funktioniert, wird sie an einen Propagationsknoten gesendet. Dort wird sie zwischengespeichert und kann später vom Client abgerufen werden.
Da es sich um normale LXMF-Nachrichten handelt, kann jede LXMF-fähige Anwendung zur Kommunikation mit der Gruppe verwendet werden.
## Aktueller Status
Die Software befindet sich derzeit noch in der Betaphase und ist noch nicht abgeschlossen.
Alle Kernfunktionen sind implementiert und funktionieren, aber Ergänzungen werden wahrscheinlich auftreten, wenn die reale Nutzung erforscht wird.
Es kann zu Fehlern kommen oder die Kompatibilität nach einem Update ist nicht mehr gewährleistet.
Die vollständige Dokumentation ist noch nicht verfügbar. Aus Zeitmangel kann ich auch nicht sagen, wann diese weiterbearbeitet werden wird.
## Bilder/ Verwendungsbeispiele
<img src="../docs/screenshots/lxmf_echo_01.png" width="200px">
## Installations Handbuch
### Installieren:
- Installieren Sie alle erforderlichen Voraussetzungen. (Standardinstallation von Reticulum. Nur erforderlich, wenn Reticulum noch nicht installiert ist).
```bash
apt update
apt upgrade
apt install python3-pip
pip install pip --upgrade
reboot
pip3 install rns
pip3 install pyserial netifaces
pip3 install lxmf
```
- Ändern Sie die Reticulum-Konfiguration entsprechend Ihren Anforderungen und Ihrem Anwendungsfall.
```bash
nano /.reticulum/config
```
- Laden Sie die [Datei](lxmf_echo.py) aus diesem Repository herunter.
```bash
wget https://raw.githubusercontent.com/SebastianObi/LXMF-Tools/main/lxmf_echo/lxmf_echo.py
```
- Machen Sie es mit folgendem Befehl ausführbar
```bash
chmod +x lxmf_echo.py
```
### Starten:
- Start mit
```bash
./lxmf_echo.py
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
- Beispiel einer Minimalkonfiguration (Überschreibung der Standardkonfiguration `config.cfg`). Dies sind die wichtigsten Einstellungen, die angepasst werden müssen. Alle anderen Einstellungen befinden sich in `config.cfg`.
```bash
nano /root/.lxmf_echo/config.cfg.owr
```
```bash
```
- Starten Sie erneut. Fertig!
```bash
./lxmf_echo.py
```
### Als Systemdienst/Dämon ausführen:
- Erstellen Sie eine Servicedatei.
```bash
nano /etc/systemd/system/lxmf_echo.service
```
- Kopieren Sie den folgenden Inhalt und passen Sie ihn an Ihre eigenen Bedürfnisse an.
```bash
[Unit]
Description=lxmf_echo.py Daemon
After=multi-user.target
[Service]
# ExecStartPre=/bin/sleep 10
Type=simple
Restart=always
RestartSec=3
User=root
ExecStart=/root/lxmf_echo.py
[Install]
WantedBy=multi-user.target
```
- Aktivieren Sie den Dienst.
```bash
systemctl enable lxmf_echo
```
- Starten Sie den Dienst.
```bash
systemctl start lxmf_echo
```
### Dienst starten/stoppen:
```bash
systemctl start lxmf_echo
systemctl stop lxmf_echo
```
### Dienst aktivieren/deaktivieren:
```bash
systemctl enable lxmf_echo
systemctl disable lxmf_echo
```
### Führen Sie mehrere Instanzen aus (um dieselbe Anwendung zu kopieren):
- Führen Sie das Programm mit einem anderen Konfigurationspfad aus.
```bash
./lxmf_echo.py -p /root/.lxmf_echo_2nd
./lxmf_echo.py -p /root/.lxmf_echo_3nd
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
### Erste Verwendung:
- Bei einem manuellen Start über die Konsole wird die eigene LXMF-Adresse angezeigt:
```
[] ...............................................................................
[] LXMF - Address: <801f48d54bc71cb3e0886944832aaf8d>
[] ...............................................................................`
```
- In der Standardeinstellung wird diese Adresse auch beim Start bekannt gegeben.
- Nun kann die Software verwendet werden.
### Inbetriebnahme Parameter:
```bash
usage: lxmf_echo.py [-h] [-p PATH] [-pr PATH_RNS] [-pl PATH_LOG] [-l LOGLEVEL] [-s] [--exampleconfig] [--exampleconfigoverride]
LXMF Echo -
optionale Argumente:
-h, --help diese Hilfemeldung anzeigen und beenden
-p PATH, --path PATH Pfad zum alternativen Konfigurationsverzeichnis
-pr PATH_RNS, --path_rns PATH_RNS
Pfad zum alternativen Reticulum-Konfigurationsverzeichnis
-pl PATH_LOG, --path_log PATH_LOG
Pfad zum alternativen Protokollverzeichnis
-l LOGLEVEL, --loglevel LOGLEVEL
-s, --service Läuft als Dienst und sollte sich in der Datei
--exampleconfig Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
--exampleconfigoverride
Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
```
### Configurationsdaten Dateien:
- config.cfg
Dies ist die Standard-Konfigurationsdatei.
- config.cfg.owr
Dies ist die Benutzerkonfigurationsdatei, die die Standardkonfigurationsdatei außer Kraft setzt.
Alle hier vorgenommenen Einstellungen haben Vorrang.
In dieser Datei können alle vom Standard abweichenden Einstellungen übersichtlich zusammengefasst werden.
Dies hat auch den Vorteil, dass alle geänderten Einstellungen bei einer Aktualisierung des Programms beibehalten werden können.
## Konfigurationshandbuch (Beispiele)
Die hier gezeigten Konfigurationen sind nur ein Teil der Gesamtkonfiguration.
Sie dienen nur dazu, die für die jeweilige Funktion notwendige und angepasste Konfiguration zu zeigen.
Alle Konfigurationen müssen in der Datei `config.cfg.owr` vorgenommen werden.
Alle möglichen Einstellungen sind in der Standard-Konfigurationsdatei `config.cfg` zu sehen.
## Admin Handbuch
Dieser Leitfaden gilt für alle Admins. Hier werden die administrativen Möglichkeiten kurz erläutert.
## User Handbuch
Diese Anleitung gilt für Benutzer oder Administratoren. Hier werden kurz die normalen Möglichkeiten der Software erklärt.
## FAQ
### Wie kann ich mit der Software beginnen?
Sie sollten den Abschnitt `Installationsanleitung` lesen. Dort ist alles kurz erklärt. Gehen Sie einfach alles von oben nach unten durch :)

105
lxmf_ping/README_de.md Normal file
View File

@ -0,0 +1,105 @@
# lxmf_ping
Dieses Programm sendet eine einstellbare Anzahl von LXMF-Nachrichten an ein Ziel. Anschließend wird eine einfache Statistik erstellt, um den Erfolg oder Misserfolg einer einzelnen Nachricht zu überprüfen. Dieses Tool kann nützlich sein, um das LXMF/Reticulum-Netzwerk mit einer bestimmten Anzahl von Nachrichten zu belasten. Damit lässt sich eine bestimmte Anzahl von Benutzern simulieren.
Weitere Informationen finden Sie in den Konfigurationsoptionen (am Ende der Programmdateien). Alles Weitere ist dort kurz dokumentiert. Nach dem ersten Start wird diese Konfiguration als Standardkonfiguration in der entsprechenden Datei angelegt.
### Merkmale
- Kompatibel mit allen LXMF-Anwendungen (NomadNet, Sideband, ...)
## Beispiele für die Verwendung
###
### Allgemeine Informationen zum Transport der Nachrichten
Alle Nachrichten zwischen Client<->Server werden als einzelne 1:1 Nachrichten im LXMF/Reticulum Netzwerk transportiert.
Dementsprechend findet zwischen diesen Endpunkten eine Verschlüsselung statt.
Wenn eine direkte Zustellung der Nachricht nicht funktioniert, wird sie an einen Propagationsknoten gesendet. Dort wird sie zwischengespeichert und kann später vom Client abgerufen werden.
Da es sich um normale LXMF-Nachrichten handelt, kann jede LXMF-fähige Anwendung zur Kommunikation mit der Gruppe verwendet werden.
## Aktueller Status
Die Software befindet sich derzeit noch in der Betaphase und ist noch nicht abgeschlossen.
Alle Kernfunktionen sind implementiert und funktionieren, aber Ergänzungen werden wahrscheinlich auftreten, wenn die reale Nutzung erforscht wird.
Es kann zu Fehlern kommen oder die Kompatibilität nach einem Update ist nicht mehr gewährleistet.
Die vollständige Dokumentation ist noch nicht verfügbar. Aus Zeitmangel kann ich auch nicht sagen, wann diese weiterbearbeitet werden wird.
## Bilder/ Verwendungsbeispiele
<img src="../docs/screenshots/lxmf_ping_01.png" width="1000px">
## Installations Handbuch
### Installation:
- Installieren Sie alle erforderlichen Voraussetzungen. (Standardinstallation von Reticulum. Nur erforderlich, wenn Reticulum noch nicht installiert ist).
```bash
apt update
apt upgrade
apt install python3-pip
pip install pip --upgrade
reboot
pip3 install rns
pip3 install pyserial netifaces
pip3 install lxmf
```
- Ändern Sie die Reticulum-Konfiguration entsprechend Ihren Anforderungen und Ihrem Anwendungsfall.
```bash
nano /.reticulum/config
```
- Laden Sie die [Datei](lxmf_ping.py) aus diesem Repository herunter.
```bash
wget https://raw.githubusercontent.com/SebastianObi/LXMF-Tools/main/lxmf_ping/lxmf_ping.py
```
- Machen Sie es mit folgendem Befehl ausführbar
```bash
chmod +x lxmf_ping.py
```
### Starten:
- Start mit
```bash
./lxmf_ping.py
```
### Inbetriebnahme Parameter:
```bash
usage: lxmf_ping.py [-h] [-p PATH] [-pr PATH_RNS] [-pl PATH_LOG] [-l LOGLEVEL] -d DEST [-t TIME] [-s SIZE] [-c COUNT] [-i INST]
LXMF Ping - Sendet periodisch Pings/Nachrichten und wertet den Status aus
optionale Argumente:
-h, --help diese Hilfemeldung anzeigen und beenden
-p PATH, --path PATH Pfad zum alternativen Konfigurationsverzeichnis
-pr PATH_RNS, --path_rns PATH_RNS
Pfad zum alternativen Reticulum-Konfigurationsverzeichnis
-pl PATH_LOG, --path_log PATH_LOG
Pfad zum alternativen Protokollverzeichnis
-l LOGLEVEL, --loglevel LOGLEVEL
-d DEST, --dest DEST Einzelner Ziel-Hash oder ,-getrennte Liste mit Ziel-Hashs oder . für zufälliges Ziel
-t TIME, --time TIME Zeit zwischen den Meldungen in Sekunden
-s SIZE, --size SIZE Größe (Länge) des Nachrichteninhalts
-c COUNT, --count COUNT
Maximale Anzahl gesendeter Nachrichten (0=no end)
-i INST, --inst INST Parallele Instanzen (unterschiedliche Absenderadressen)
```
## User Handbuch
Diese Anleitung gilt für Benutzer oder Administratoren. Hier werden kurz die normalen Möglichkeiten der Software erklärt.
## FAQ
### Wie kann ich mit der Software beginnen?
Sie sollten den Abschnitt `Installationsanleitung` lesen. Dort ist alles kurz erklärt. Gehen Sie einfach alles von oben nach unten durch :)

View File

@ -0,0 +1,261 @@
# lxmf_provisioning
Dieses Programm bietet die Möglichkeit, Clients zu provisionieren. Dazu gehört zum Beispiel: Die Ankündigung von Software-Updates. Die Registrierung neuer Benutzer. Die Speicherung von Telemetriedaten, die die Clients an den Server senden. Die Daten werden in einer PostgreSQL-Datenbank gespeichert. Der Quellcode kann natürlich angepasst werden, um die Daten auf eine andere Weise zu speichern.
Weitere Informationen finden Sie in den Konfigurationsoptionen (am Ende der Programmdateien). Alles Weitere ist dort kurz dokumentiert. Nach dem ersten Start wird diese Konfiguration als Standardkonfiguration in der entsprechenden Datei angelegt.
### Eigenschaften
- Ankündigung der Server- und Softwareversionen
- Registrierung der Benutzer
- Sammlung von Telemetriedaten
- Speicherung der Daten in PostgreSQL, ...
## Beispiele für die Verwendung
### Allgemeine Informationen, wie die Nachrichten/Daten transportiert werden
Alle Ansagen werden unverschlüsselt mit ihrem eigenen Typ/Namen übertragen, der nicht in der Nomadnet/Sideband-Ansagenliste angezeigt wird.
Alle Nachrichten zwischen Client<->Server werden als einzelne 1:1 Nachrichten im LXMF/Reticulum Netzwerk transportiert.
Dementsprechend findet zwischen diesen Endpunkten eine Verschlüsselung statt.
## Aktueller Status
Es handelt sich derzeit um eine Betasoftware, die noch in Arbeit ist.
Alle Kernfunktionen sind implementiert und funktionieren, aber Ergänzungen werden wahrscheinlich auftreten, wenn die reale Nutzung erforscht wird.
Es kann zu Fehlern kommen oder die Kompatibilität nach einem Update ist nicht mehr gewährleistet.
Die vollständige Dokumentation ist noch nicht verfügbar. Aus Zeitmangel kann ich auch nicht sagen, wann diese weiterbearbeitet werden wird.
## Bilder / Verwendungsbeispiele
## Installations Handbuch
### Installieren:
- Installieren Sie alle erforderlichen Voraussetzungen. (Standardinstallation von Reticulum. Nur erforderlich, wenn Reticulum noch nicht installiert ist).
```bash
apt update
apt upgrade
apt install python3-pip
pip install pip --upgrade
reboot
pip3 install rns
pip3 install pyserial netifaces
pip3 install lxmf
```
- Ändern Sie die Reticulum-Konfiguration entsprechend Ihren Anforderungen und Ihrem Anwendungsfall.
```bash
nano /.reticulum/config
```
- Laden Sie die [Datei](lxmf_provisioning.py) aus diesem Repository herunter.
```bash
wget https://raw.githubusercontent.com/SebastianObi/LXMF-Tools/main/lxmf_provisioning/lxmf_provisioning.py
```
- Machen Sie es mit folgendem Befehl ausführbar
```bash
chmod +x lxmf_provisioning.py
```
### Starten:
- Starte mit
```bash
./lxmf_provisioning.py
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
- Beispiel einer Minimalkonfiguration (Überschreibung der Standardkonfiguration `config.cfg`). Dies sind die wichtigsten Einstellungen, die angepasst werden müssen. Alle anderen Einstellungen befinden sich in `config.cfg`.
```bash
nano /root/.lxmf_provisioning/config.cfg.owr
```
```bash
```
- Starten Sie erneut. Fertig!
```bash
./lxmf_provisioning.py
```
### Als Systemdienst/Dämon ausführen:
- Erstellen Sie eine Servicedatei.
```bash
nano /etc/systemd/system/lxmf_provisioning.service
```
- Kopieren Sie den folgenden Inhalt und passen Sie ihn an Ihre eigenen Bedürfnisse an.
```bash
[Unit]
Description=LXMF Provisioning Daemon
After=multi-user.target
[Service]
# ExecStartPre=/bin/sleep 10
Type=simple
Restart=always
RestartSec=3
User=root
ExecStart=/root/lxmf_provisioning.py
[Install]
WantedBy=multi-user.target
```
- Aktivieren Sie den Dienst.
```bash
systemctl enable lxmf_provisioning
```
- Starten Sie den Dienst.
```bash
systemctl start lxmf_provisioning
```
### Dienst starten/stoppen:
```bash
systemctl start lxmf_provisioning
systemctl stop lxmf_provisioning
```
### Dienst aktivieren/deaktivieren:
```bash
systemctl enable lxmf_provisioning
systemctl disable lxmf_provisioning
```
### Führen Sie mehrere Instanzen aus (Kopieren der gleichen Anwendung):
- Führen Sie das Programm mit einem anderen Konfigurationspfad aus.
```bash
./lxmf_provisioning.py -p /root/.lxmf_provisioning_2nd
./lxmf_provisioning.py -p /root/.lxmf_provisioning_3nd
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
### Erste Verwendung:
- Bei einem manuellen Start über die Konsole wird die eigene LXMF-Adresse angezeigt:
```
[] ...............................................................................
[] LXMF - Address: <801f48d54bc71cb3e0886944832aaf8d>
[] ...............................................................................`
```
- In der Standardeinstellung wird diese Adresse auch beim Start bekannt gegeben.
- Diese Provisioning-Server-Adresse muss den Clients hinzugefügt werden.
- Nun kann die Software verwendet werden.
### Startup Parameter:
```bash
usage: lxmf_provisioning.py [-h] [-p PATH] [-pr PATH_RNS] [-pl PATH_LOG] [-l LOGLEVEL] [-s] [--exampleconfig] [--exampleconfigoverride]
LXMF Provisioning Server -
optionale Argumente:
-h, --help diese Hilfemeldung anzeigen und beenden
-p PATH, --path PATH Pfad zum alternativen Konfigurationsverzeichnis
-pr PATH_RNS, --path_rns PATH_RNS
Pfad zum alternativen Reticulum-Konfigurationsverzeichnis
-pl PATH_LOG, --path_log PATH_LOG
Pfad zum alternativen Protokollverzeichnis
-l LOGLEVEL, --loglevel LOGLEVEL
-s, --service Läuft als Dienst und Loggt in Datei
--exampleconfig Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
--exampleconfigoverride
Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
```
### Configurationsdaten Dateien:
- config.cfg
Dies ist die Standardkonfigurationsdatei.
- config.cfg.owr
Dies ist die Benutzerkonfigurationsdatei, die die Standardkonfigurationsdatei außer Kraft setzt.
Alle hier vorgenommenen Einstellungen haben Vorrang.
In dieser Datei können alle vom Standard abweichenden Einstellungen übersichtlich zusammengefasst werden.
Dies hat auch den Vorteil, dass alle geänderten Einstellungen bei einer Aktualisierung des Programms beibehalten werden können.
## Konfigurations Handbuch (Beispiele)
Die hier gezeigten Konfigurationen sind nur ein Teil der Gesamtkonfiguration.
Sie dient nur dazu, die für die jeweilige Funktion notwendige und angepasste Konfiguration zu zeigen.
Alle Konfigurationen müssen in der Datei `config.cfg.owr` vorgenommen werden.
Alle möglichen Einstellungen sind in der Standard-Konfigurationsdatei `config.cfg` zu sehen.
### Standardfunktion (Versionen ankündigen, Benutzerregistrierung, Telemetrie):
- `config.cfg.owr`
```
[lxmf]
announce_periodic = Yes
announce_periodic_interval = 15 #Minutes
[database]
host = 127.0.0.1
port = 5432
user = postgres
password = password
database = test
table_registration = tbl_account
table_telemetry = tbl_telemetry
[features]
announce_versions = True
registration = True
telemetry = True
[data]
v_s = 0.1.4 #Version software
v_c = 2022-11-29 20:00 #Version config
v_d = 2022-11-29 20:00 #Version data
v_a = 2022-11-29 20:00 #Version auth
u_s = https:// #URL Software
```
### Benutzerdefinierte Funktion (Versionen ankündigen):
- `config.cfg.owr`
```
[lxmf]
announce_periodic = Yes
announce_periodic_interval = 15 #Minutes
[database]
host = 127.0.0.1
port = 5432
user = postgres
password = password
database = test
table_registration = tbl_account
table_telemetry = tbl_telemetry
[features]
announce_versions = True
registration = False
telemetry = False
[data]
v_s = 0.1.4 #Version software
v_c = 2022-11-29 20:00 #Version config
v_d = 2022-11-29 20:00 #Version data
v_a = 2022-11-29 20:00 #Version auth
u_s = https:// #URL Software
```
## Handbuch für Administratoren
Dieses Handbuch gilt für alle Admins. Hier werden die administrativen Möglichkeiten kurz erläutert.
## Benutzerhandbuch
Diese Anleitung gilt für Benutzer oder Administratoren. Hier werden kurz die normalen Möglichkeiten der Software erklärt.
## FAQ
### Wie kann ich mit der Software beginnen?
Sie sollten den Abschnitt `Installationsanleitung` lesen. Dort ist alles kurz erklärt. Gehen Sie einfach alles von oben nach unten durch :)

202
lxmf_terminal/README_de.md Normal file
View File

@ -0,0 +1,202 @@
# lxmf_terminal
Dieses Programm bietet eine vollständige Terminalsitzung auf dem Server. Es können beliebige Befehle auf dem Zielgerät ausgeführt werden. Die Kommunikation erfolgt über einzelne LXMF-Nachrichten. Dies bietet den Vorteil, dass einfache Terminalbefehle von jeder LXMF-fähigen Anwendung genutzt werden können.
Weitere Informationen finden Sie in den Konfigurationsoptionen (am Ende der Programmdateien). Alles Weitere ist dort kurz dokumentiert. Nach dem ersten Start wird diese Konfiguration als Standardkonfiguration in der entsprechenden Datei angelegt.
### Merkmale
- Kompatibel mit allen LXMF-Anwendungen (NomadNet, Sideband, ...)
## Beispiele für die Verwendung
###
### Allgemeine Informationen zum Transport der Nachrichten
Alle Nachrichten zwischen Client<->Server werden als einzelne 1:1 Nachrichten im LXMF/Reticulum Netzwerk transportiert.
Dementsprechend findet zwischen diesen Endpunkten eine Verschlüsselung statt.
Wenn eine direkte Zustellung der Nachricht nicht funktioniert, wird sie an einen Propagationsknoten gesendet. Dort wird sie zwischengespeichert und kann später vom Client abgerufen werden.
Da es sich um normale LXMF-Nachrichten handelt, kann jede LXMF-fähige Anwendung zur Kommunikation mit der Gruppe verwendet werden.
## Aktueller Status
Die Software befindet sich derzeit noch in der Betaphase und ist noch nicht abgeschlossen.
Alle Kernfunktionen sind implementiert und funktionieren, aber Ergänzungen werden wahrscheinlich auftreten, wenn die reale Nutzung erforscht wird.
Es kann zu Fehlern kommen oder die Kompatibilität nach einem Update ist nicht mehr gewährleistet.
Die vollständige Dokumentation ist noch nicht verfügbar. Aus Zeitmangel kann ich auch nicht sagen, wann diese weiterbearbeitet werden wird.
## Bilder / Verwendungsbeispiele
<img src="../docs/screenshots/lxmf_terminal_01.png" width="200px">
## Installations Handbuch
### Installieren:
- Installieren Sie alle erforderlichen Voraussetzungen. (Standardinstallation von Reticulum. Nur erforderlich, wenn Reticulum noch nicht installiert ist).
```bash
apt update
apt upgrade
apt install python3-pip
pip install pip --upgrade
reboot
pip3 install rns
pip3 install pyserial netifaces
pip3 install lxmf
```
- Ändern Sie die Reticulum-Konfiguration entsprechend Ihren Anforderungen und Ihrem Anwendungsfall.
```bash
nano /.reticulum/config
```
- Laden Sie die [Datei](lxmf_terminal.py) aus diesem Repository herunter.
```bash
wget https://raw.githubusercontent.com/SebastianObi/LXMF-Tools/main/lxmf_terminal/lxmf_terminal.py
```
- Machen Sie es mit folgendem Befehl ausführbar
```bash
chmod +x lxmf_terminal.py
```
### Starten:
- Start mit
```bash
./lxmf_terminal.py
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
- Beispiel einer Minimalkonfiguration (Überschreibung der Standardkonfiguration `config.cfg`). Dies sind die wichtigsten Einstellungen, die angepasst werden müssen. Alle anderen Einstellungen befinden sich in `config.cfg`.
```bash
nano /root/.lxmf_terminal/config.cfg.owr
```
```bash
```
- Starten Sie erneut. Fertig!
```bash
./lxmf_terminal.py
```
### Als Systemdienst/Dämon ausführen:
- Erstellen einer Servicedatei.
```bash
nano /etc/systemd/system/lxmf_terminal.service
```
- Kopieren Sie den folgenden Inhalt und passen Sie ihn an Ihre eigenen Bedürfnisse an.
```bash
[Unit]
Description=lxmf_terminal.py Daemon
After=multi-user.target
[Service]
# ExecStartPre=/bin/sleep 10
Type=simple
Restart=always
RestartSec=3
User=root
ExecStart=/root/lxmf_terminal.py
[Install]
WantedBy=multi-user.target
```
- Enable the service.
```bash
systemctl enable lxmf_terminal
```
- Start the service.
```bash
systemctl start lxmf_terminal
```
### Dienst starten/stoppen:
```bash
systemctl start lxmf_terminal
systemctl stop lxmf_terminal
```
### Dienst aktivieren/deaktivieren:
```bash
systemctl enable lxmf_terminal
systemctl disable lxmf_terminal
```
### Führen Sie mehrere Instanzen aus (Kopieren der gleichen Anwendung):
- Führen Sie das Programm mit einem anderen Konfigurationspfad aus.
```bash
./lxmf_terminal.py -p /root/.lxmf_terminal_2nd
./lxmf_terminal.py -p /root/.lxmf_terminal_3nd
```
- Nach dem ersten Start bearbeiten Sie die Konfigurationsdatei, um sie an Ihre Bedürfnisse und Ihren Anwendungsfall anzupassen. Der Speicherort der Datei wird angezeigt.
### Erste Verwendung:
- Bei einem manuellen Start über die Konsole wird die eigene LXMF-Adresse angezeigt:
```
[] ...............................................................................
[] LXMF - Address: <801f48d54bc71cb3e0886944832aaf8d>
[] ...............................................................................`
```
- In der Standardeinstellung wird diese Adresse auch beim Start bekannt gegeben.
- Nun kann die Software verwendet werden.
### Inbetriebnahme Parameter :
```bash
usage: lxmf_terminal.py [-h] [-p PATH] [-pr PATH_RNS] [-pl PATH_LOG] [-l LOGLEVEL] [-s] [--exampleconfig] [--exampleconfigoverride]
LXMF Terminal -
optionale Argumente:
-h, --help diese Hilfemeldung anzeigen und beenden
-p PATH, --path PATH Pfad zum alternativen Konfigurationsverzeichnis
-pr PATH_RNS, --path_rns PATH_RNS
Pfad zum alternativen Reticulum-Konfigurationsverzeichnis
-pl PATH_LOG, --path_log PATH_LOG
Pfad zum alternativen Protokollverzeichnis
-l LOGLEVEL, --loglevel LOGLEVEL
-s, --service Läuft als Dienst und sollte sich in der Datei
--exampleconfig Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
--exampleconfigoverride
Ausführliches Konfigurationsbeispiel nach stdout ausgeben und beenden
```
### Configurationsdaten Dateien:
- config.cfg
Dies ist die Standard Konfigurationsdatei.
- config.cfg.owr
Dies ist die Benutzerkonfigurationsdatei, die die Standardkonfigurationsdatei außer Kraft setzt.
Alle hier vorgenommenen Einstellungen haben Vorrang.
In dieser Datei können alle vom Standard abweichenden Einstellungen übersichtlich zusammengefasst werden.
Dies hat auch den Vorteil, dass alle geänderten Einstellungen bei einer Aktualisierung des Programms beibehalten werden können.
## Konfigurationshandbuch (Beispiele)
Die hier gezeigten Konfigurationen sind nur ein Teil der Gesamtkonfiguration.
Sie dienen nur dazu, die für die jeweilige Funktion notwendige und angepasste Konfiguration zu zeigen.
Alle Konfigurationen müssen in der Datei `config.cfg.owr` vorgenommen werden.
Alle möglichen Einstellungen sind in der Standard-Konfigurationsdatei `config.cfg` zu sehen.
## Admin Handbuch
Dieser Leitfaden gilt für alle Admins. Hier werden die administrativen Möglichkeiten kurz erläutert.
## User Handbuch
Diese Anleitung gilt für Benutzer oder Administratoren. Hier werden kurz die normalen Möglichkeiten der Software erklärt.
## FAQ
### Wie kann ich mit der Software beginnen?
Sie sollten den Abschnitt `Installationsanleitung` lesen. Dort ist alles kurz erklärt. Gehen Sie einfach alles von oben nach unten durch :)