some modifications made to let it run in my environment (reverse proxy) - I also suggest to not let this run as root user, have a look at my setup that runs behind a reverse proxy at home: https://oe7drt.com/posts/2024/62-a-slim-dstar-gateway-on-a-raspberry-pi-2/#install-a-dashboard
Find a file
2024-01-12 16:47:34 -08:00
client Added useful URLs 2024-01-12 16:47:34 -08:00
util Service File 2024-01-06 17:27:32 -08:00
.gitignore Don't track PEM and modules 2024-01-09 10:54:34 -08:00
dashboard.ini Added useful URLs 2024-01-12 16:47:34 -08:00
index.js Added useful URLs 2024-01-12 16:47:34 -08:00
package-lock.json From NW7DR 2024-01-05 13:02:31 -08:00
package.json From NW7DR 2024-01-05 13:02:31 -08:00
README.md Update README.md 2024-01-06 18:08:00 -08:00

dsgwdashboard

This is a realtime Dashboard for F4FXL's DStarGateway

It is written in JavaScript. The server side is a NodeJS application using the Express framework that runs over HTTPS and uses secure WebSockets (WSS) to pass data over the Internet to the web browser. WSS requires encryption which is why it is implemented with that feature.

Installing this will require some familiarity with Linux/Unix command line and system.

You will need to have a domain name for the site and current certificates tied to that domain. The index.js file, which defines the HTTPS server, is looking for key.pem and cert.pem in the same directory as index.js. I suggest using (Certbot)[https://certbot.eff.org/] to obtain free signed certificates that all major browsers recognize as legitimate. I typically run Apache2 or another webserver to allow Certbot to authenticate the site to create the certificates. The certificates will typically reside in /etc/live/your domain name and I simply soft link (ls -s) them from the dsgwdashboard directory. You can disable the webserver, such as Apache2 or NGNIX once you have the certificates.

Before starting up the dsgwdashboard you will want to have DStarGateway running, to prepopulate the log files. Your first task will be to edit dashboard.ini to put in your hostname and to ensure file paths match your install of DStarGateway. The dashboard parses those log files in realtime to update the dashboard.

This dashboard runs under a current version of NodeJS. Your distribution may install an older version, so use the methods documented at (nodesource)[https://github.com/nodesource/distributions]. Make sure node -v returns the version you installed.

Your next task is to install the modules used with the command npm install -save within the dsgwdashboard directory.

You can start the dsgwdashboard server on the command line by entering the install directory for dsgwdashboard and typing sudo node index.js It should also run under the newer/faster Bun Runtime

If it comes up successfully, go to a browser put in a HTTPS request to your domain name. If you get a dashboard, you have done everything correctly.

I have included a systemd service file in the util subdirectory which can be copied to /lib/systemd/system and managed with the sudo systemctl command.

This program is still under development, but you are welcome to try it out. Consider it alpha code.