This program is a simple echo server. All received messages are sent back 1:1 as an answer. This can be used as a simple counterpart to test the chat functionality of applications.
For more information, see the configuration options (at the end of the program files). Everything else is briefly documented there. After the first start this configuration will be created as default config in the corresponding file.
### Features
- Compatible with all LXMF applications (NomadNet, Sideband, ...)
## Examples of use
###
### General info how the messages are transported
All messages between client<->server are transported as single 1:1 messages in the LXMF/Reticulum network.
Accordingly, encryption takes place between these end points.
If a direct delivery of the message does not work, it is sent to a propagation node. There it is stored temporarily and can be retrieved by the client later.
As these are normal LXMF messages, any LXMF capable application can be used to communicate with the group.
- After the first start edit the configuration file to suit your needs and use-case. The file location is displayed.
- Example minimal configuration (override of the default config `config.cfg`). These are the most relevant settings that need to be adjusted. All other settings are in `config.cfg`
```bash
nano /root/.lxmf_echo/config.cfg.owr
```
```bash
```
- Start it again. Finished!
```bash
./lxmf_echo.py
```
### Run as a system service/deamon:
- Create a service file.
```bash
nano /etc/systemd/system/lxmf_echo.service
```
- Copy and edit the following content to your own needs.
```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
```
- Enable the service.
```bash
systemctl enable lxmf_echo
```
- Start the service.
```bash
systemctl start lxmf_echo
```
### Start/Stop service:
```bash
systemctl start lxmf_echo
systemctl stop lxmf_echo
```
### Enable/Disable service:
```bash
systemctl enable lxmf_echo
systemctl disable lxmf_echo
```
### Run several instances (To copy the same application):
- Run the program with a different configuration path.
```bash
./lxmf_echo.py -p /root/.lxmf_echo_2nd
./lxmf_echo.py -p /root/.lxmf_echo_3nd
```
- After the first start edit the configuration file to suit your needs and use-case. The file location is displayed.
### First usage:
- With a manual start via the console, the own LXMF address is displayed: