mirror of
https://github.com/markqvist/LXMF-Tools.git
synced 2025-01-11 15:29:45 -05:00
commit
a2e7f2195e
196
README_de.md
Normal file
196
README_de.md
Normal 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
|
5
lxmf_bridge_matrix/README_de.md
Normal file
5
lxmf_bridge_matrix/README_de.md
Normal 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.
|
5
lxmf_bridge_meshtastic/README_de.md
Normal file
5
lxmf_bridge_meshtastic/README_de.md
Normal 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.
|
223
lxmf_bridge_mqtt/README_de.md
Normal file
223
lxmf_bridge_mqtt/README_de.md
Normal 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 :)
|
2
lxmf_bridge_telegram/README_de.md
Normal file
2
lxmf_bridge_telegram/README_de.md
Normal 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
210
lxmf_chatbot/README_de.md
Normal 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
201
lxmf_cmd/README_de.md
Normal 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 :)
|
755
lxmf_distribution_group/README_de.md
Normal file
755
lxmf_distribution_group/README_de.md
Normal 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 :)
|
301
lxmf_distribution_group_minimal/README_de.md
Normal file
301
lxmf_distribution_group_minimal/README_de.md
Normal 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
202
lxmf_echo/README_de.md
Normal 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
105
lxmf_ping/README_de.md
Normal 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 :)
|
261
lxmf_provisioning/README_de.md
Normal file
261
lxmf_provisioning/README_de.md
Normal 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
202
lxmf_terminal/README_de.md
Normal 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 :)
|
Loading…
Reference in New Issue
Block a user