Wachalarm-IP-Web/server/api.js
2020-05-28 16:31:01 +02:00

95 lines
3.2 KiB
JavaScript
Executable File

module.exports = function (io, sql, app_cfg, waip) {
// Module laden
const io_api = require('socket.io-client');
// Namespace API festlegen
var nsp_api = io.of('/api');
// ###
// Socket.IO Empfangs-API (anderer Server stellt Verbindung her und sendet Daten)
// ###
if (app_cfg.api.enabled) {
nsp_api.on('connection', function (socket) {
// versuche Remote-IP zu ermitteln
var remote_ip = socket.handshake.headers["x-real-ip"] || socket.handshake.headers['x-forwarded-for'] || socket.request.connection.remoteAddress;
//TODO pruefen ob Verbindung mit passendem Geheimnis und aus IP-Bereich, das Ergebnis loggen
// in Liste der Clients mit aufnehmen
sql.db_update_client_status(socket, 'api');
// Neuen Einsatz speichern
socket.on('new_waip', function (data) {
waip.einsatz_speichern(data);
sql.db_log('API', 'Neuer Einsatz von ' + remote_ip + ': ' + data);
});
// neue externe Rueckmeldung speichern
socket.on('new_rmld', function (data) {
sql.db_rmld_save(data, function (result) {
if (result) {
waip.rmld_verteilen_by_uuid(data.waip_uuid, data.rmld_uuid);
sql.db_log('API', 'Rückmeldung von ' + remote_ip + ' gespeichert: ' + data);
} else {
sql.db_log('API', 'Fehler beim speichern der Rückmeldung von ' + remote_ip + ': ' + data);
};
});
});
// Disconnect
socket.on('disconnect', function () {
sql.db_log('API', 'Schnittstelle von ' + remote_ip + ' (' + socket.id + ') geschlossen.');
sql.db_client_delete(socket);
});
});
};
// ###
// Socket.IO Sende-API (Daten an Server senden, die Verbindung hergestellt haben)
// ###
if (app_cfg.endpoint.enabled) {
// Verbindung zu anderem Server aufbauen
// TODO Verbindungsaufbau mit passendem Geheimnis absichern
var remote_api = io_api.connect(app_cfg.endpoint.host, {
reconnect: true
});
// Verbindungsaufbau protokollieren
remote_api.on('connect', function () {
sql.db_log('API', 'Verbindung mit ' + app_cfg.endpoint.host + ' ergestellt');
});
// Fehler protokollieren
remote_api.on('connect_error', function (err) {
sql.db_log('API', 'Verbindung zu ' + app_cfg.endpoint.host + ' verloren, Fehler: ' + err);
});
// Verbindungsabbau protokollieren
remote_api.on('disconnect', function (reason) {
sql.db_log('API', 'Verbindung zu ' + app_cfg.endpoint.host + ' verloren, Fehler: ' + reason);
});
};
function send_new_waip(data) {
// Alarm an Remote-Server senden, falls funktion aktiviert
if (app_cfg.endpoint.enabled) {
remote_api.emit('new_waip', data);
sql.db_log('API', 'Neuen Wachalarm an ' + app_cfg.endpoint.host + ' gesendet: ' + data);
};
};
function send_new_rmld(data) {
// Rückmeldung an Remote-Server senden, falls funktion aktiviert
if (app_cfg.endpoint.enabled) {
remote_api.emit('new_rmld', data);
sql.db_log('API', 'Rückmeldung an ' + app_cfg.endpoint.host + ' gesendet: ' + data);
};
};
return {
send_new_waip: send_new_waip,
send_new_rmld: send_new_rmld
};
};