Go to file
2019-03-10 22:04:40 +01:00
public Update waip.js 2019-03-07 16:16:09 +01:00
server Update waip_io.js 2019-03-10 10:26:32 +01:00
views Update login.pug 2019-03-10 09:36:15 +01:00
.gitignore Update .gitignore 2019-03-10 09:34:00 +01:00
LICENSE.md License & Readme 2018-12-06 10:02:50 +01:00
package-lock.json Update package-lock.json 2019-03-06 15:17:52 +01:00
package.json Update package.json 2019-03-06 15:17:45 +01:00
README.md Update README.md 2019-03-10 22:04:40 +01:00
server.js Zertifikate hinterlegt 2019-03-10 10:04:34 +01:00

Wachalarm-IP-Web

enter image description here In diesem Repository wird der Quellcode der Web-Version des Wachalarm-IP veröffentlicht. Die Anwendung wurde vollständig in Node.js geschrieben und kann unter Beachtung der Lizenzbedingungen kostenlos von jedem genutzt werden. Ziel dieser Version des Wachalarms soll es sein, auf jedem Endgerät - egal ob Windows, Linux, Mac, PC oder Smartphone - Alarme anzuzeigen ohne zusätzliche Software zu installieren. Da es sich beim Wachalarm-IP-Web um eine reine Web-Server-Anwendung handelt, sollte dieser am besten durch eine Leitstelle betrieben werden, die Einsatzalarme direkt an das System übergibt. Der Zugriff erfolgt dann innerhalb eines geschützten Netzwerkes (VPN, LAN etc.) oder direkt über das Internet (sofern freigegeben und gewollt). Der Web-Server empfängt Einsatzdaten über eine definierte Schnittstelle aus dem Einsatzleitsystem (oder anderen Systemen) und übersendet diese dann an die jeweiligen Clients.

Funktionsumfang

  • Anzeige verschiedener Wachalarme für einzelne Wachen, Träger oder ganze Kreise
  • Ausgabe synthetischer Sprachdurchsagen (Gong, Einsatzart, Stichwort, Ort, Ortsteile, beteiligte Einsatzmittel, Sondersignal)
  • Kartenmodul zur Anzeige des Einsatzortes
  • Responsive Webdesign - gleiche Anzeige des Wachalarms auf allen Geräten, Unterstützung von Hoch- und Querformat
  • Rechteverwaltung von Benutzern zur Sicht von Wachalarmen verschiedenster Wachen, Träger oder ganzer Kreise
  • Verschlüsselte Übertragung der Einsatzdaten (https)
  • Anzeige eines reduzierten (Datenschutz beachtenden) Wachalarms bei fehlender Berechtigung
  • Steuerung der übermittelten Daten durch den Server - auf dem Client werden keine Daten gespeichert (außer dem Session-Cookie)
  • Volle kompatibilität mit den gängigen Browsern (getestet in Chrome, Firefox, Safari, Microsoft Edge)
  • Basierend auf modernsten Web-Technologien (Node.js, Express, Socket.io, Passport, SQLite, Bootstrap, Leaflet)

Installation & Konfiguration

Vorbereitung & Installation

  • Installation von Node.js (Version 10 LTS oder höher)
  • Installation von FFmpeg (wird benötigt um Sound-Dateien umzuwandeln und neu zusammen zu setzen)
  • Download des Quellcodes (Master)
  • Entpacken der *.zip-Datei
  • Komandozeile öffnen (Powershell, CMD, Terminal etc.) und in das entpackte Verzeichnis wechseln. Dort folgende Befehle eingeben 6. npm install (lädt und installiert alle Pakete) 7. npm start (startet den Web-Server)

Server-Einstellungen

In der Unterverzeichnis Datei ./server/app_cfg.js können individuelle Einstellungen für den Betrieb des Servers gesetzt werden:

  • http_port: 3000 (HTTP-Port der Anwendung)
  • https_port: 3443 (HTTPS-Port der Anwendung)
  • udpport: 60233 (UDP-Port der Schnittstelle)
  • database: './database.sqlite3' (Speicherort der Datenbank)
  • soundpath: '/public/media/' (Speicherort der Sound-Dateien)
  • mediapath: '/media/' (Pfad der Mediendateien)
  • defaultuser: 'me' (Standard-Administrator, beim ersten Start)
  • defaultpass: '123' (Standarad-Administrator-Passwort)
  • defaultuserip: '127.0.0.1' (Standard-IP des Administrators)
  • ip_auth_range: ['::ffff:172.16.5.0/24', '::ffff:192.168.2.0/24'] (Bereich / Bereiche aus denen eine Anmeldung per IP-Adresse zulässig ist)
  • saltRounds: 10 (Anzahl der Verschlüsselungsrunden für Kennwörter)
  • sessionsecret: '0987654321abcdef#xyz' (Geheimnis für Session-Speicherung)
  • app_id: process.pid (Prozess-ID)
  • map_tile: 'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png' (Provider der Hintergrund-Karte des Wachalarms)

Zertifikat

Erläuterung folgt. Selbst signiertes Zertifikat erstellen:

openssl req -nodes -new -x509 -keyout server.key -out server.cert

Benutzer verwalten

Erläuterung folgt.

Schnittstelle

Erläuterung folgt.

Beispiel JSON

{
  "einsatzdaten": {
    "nummer": "419123456",
    "alarmzeit": "19.02.16&17:16",
    "art": "Brandeinsatz",
    "stichwort": "B:Sonderobjekt",
    "sondersignal": 1,
    "besonderheiten": "Probeeinsatz für Wachalarm-IP-Web der Leitstelle Lausitz!",
    "patient": "Mustermann, Max"
  },
  "ortsdaten": {
    "ort": "Cottbus",
    "ortsteil": "Madlow",
    "strasse": "Dresdener-Straße 46",
    "objekt": "Regionalleitstelle Lausitz",
    "objektnr": "-1",
    "objektart": "",
    "wachfolge": "520201",
    "wgs84_x": "51.733266",
    "wgs84_y": "14.337831"
  },
  "alarmdaten": [
    {
      "typ": "ALARM",
      "netzadresse": "192.168.1.120",
      "wachenname": "CB FW Cottbus 1",
      "einsatzmittel": "FL CB 01/82-01",
      "zeit_a": "17:16",
      "zeit_b": "",
      "zeit_c": ""
    },
    {
      "typ": "ALARM",
      "netzadresse": "",
      "wachenname": "CB FW Cottbus 2",
      "einsatzmittel": "FL CB 02/46-01",
      "zeit_a": "17:16",
      "zeit_b": "",
      "zeit_c": ""
    }
  ]
}

Screenshots

Startseite

FireShot Capture 001 - Startseite - localhost

Einsatz (Querformat)

FireShot Capture 005 - Alarmmonitor - localhost

Einsatz (Hochformat)

FireShot Capture 006 - Alarmmonitor - localhost

Bildschirmschoner

FireShot Capture 002 - Alarmmonitor - localhost

Login

FireShot Capture 003 - Login - localhost

Benutzerverwaltung

FireShot Capture 004 - Benutzer und Rechte verwalten - localhost

Lizenz

[Creative Commons Attribution Share Alike 4.0 International]