update Di 26. Mai 16:01:01 CEST 2020

This commit is contained in:
Robert Richter 2020-05-26 16:01:01 +02:00
parent 0a47010425
commit 85834350fb

View File

@ -1,45 +1,44 @@
module.exports = function (io, io_api, sql, app_cfg, waip) { module.exports = function (io, io_api, sql, app_cfg, waip) {
// Module laden // Module laden
const io_api = require('socket.io-client'); const io_api = require('socket.io-client');
// Socket.IO API (anderer Server stellt Verbindung her und sendet Daten)
// Socket.IO API if (app_cfg.api.enabled) {
// Namespace API
var nsp_api = io.of('/api');
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;
if (app_cfg.api.enabled) { //TODO pruefen ob Verbindung mit passendem Geheimnis und aus IP-Bereich
var nsp_api = io.of('/api');
nsp_api.on('connection', function (socket) { // in Liste der Clients mit aufnehmen
// versuche Remote-IP zu ermitteln sql.db_update_client_status(socket, 'api');
var remote_ip = socket.handshake.headers["x-real-ip"] || socket.handshake.headers['x-forwarded-for'] || socket.request.connection.remoteAddress; // Neuen Einsatz speichern
//TODO pruefen ob Verbindung mit passendem Geheimnis und aus IP-Bereich socket.on('new_waip', function (data) {
//secret: 'asdfwert1234567890#', waip.einsatz_speichern(data);
//access_list: ['192.168.2.20', '192.168.2.30'] sql.db_log('API', 'Neuer Einsatz von ' + remote_ip + ': ' + data);
});
// in Liste der Clients mit aufnehmen // neue externe Rueckmeldung speichern
sql.db_update_client_status(socket, 'api'); socket.on('new_rmld', function (data) {
// Neuen Einsatz speichern sql.db_save_rmld(data, function (result) {
socket.on('new_waip', function (data) { if (result) {
sql.db_log('API', 'Neuer Einsatz von ' + remote_ip + ': ' + data); waip.rmld_verteilen_by_uuid(data.waip_uuid, data.rmld_uuid);
waip.einsatz_speichern(data); sql.db_log('API', 'Rückmeldung von ' + remote_ip + ' gespeichert: ' + data);
}); } else {
socket.on('new_rmld', function (data) { sql.db_log('API', 'Fehler beim speichern der Rückmeldung von ' + remote_ip + ': ' + data);
sql.db_save_rmld(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);
});
}); });
}; });
// Disconnect
socket.on('disconnect', function () {
sql.db_log('API', 'Schnittstelle von ' + remote_ip + ' (' + socket.id + ') geschlossen.');
sql.db_client_delete(socket);
});
});
};